data:image/s3,"s3://crabby-images/26c2f/26c2fdc588a11a8b121fe7a3c308e9fe2b4194ea" alt="Sysinternals rdcman"
I had the same problem as you (my passwords are encrypted using a certificate).
data:image/s3,"s3://crabby-images/efc37/efc3712fba56d8d18fcdfeccde891bd3d4d2cac7" alt="sysinternals rdcman sysinternals rdcman"
$logonCredentials = Select-XML -Xml $XML -XPath '//logonCredentials' $EncryptionSettings = New-Object -TypeName RdcMan.EncryptionSettings $RDGFile = "$env:USERPROFILE\Documents\RDPConnections.rdg"Ĭopy-Item $RDCMan "$TempLocation\RDCMan.dll" $RDCMan = "C:\Program Files (x86)\Microsoft\Remote Desktop Connection Manager\RDCMan.exe" Needless to say, I found the password I needed! If the credentials were added by another account or on another system, you will get a “Failed to decrypt” error as seen below, which is the same error you get if you try to copy the RDG file and open it on another computer or with another user profile. The passwords can only be decrypted with the user profile that added them to the RDG file, however, so they are still reasonably secure. Using a handy trick blogged by Thomas Prud’Homme, I decrypted all the credentials found in the RDG file. It’s just an XML file, so can be easily parsed with PowerShell.
data:image/s3,"s3://crabby-images/304d9/304d9653efafc3fae51108eaa267203aad19ab07" alt="sysinternals rdcman sysinternals rdcman"
The credentials are stored in encrypted form in the RDG file you create for your RDP connections.
data:image/s3,"s3://crabby-images/a8b6b/a8b6b753191c55140643124cde8a95bb3e2c365c" alt="sysinternals rdcman sysinternals rdcman"
Of course, it crossed my mind whether these credentials could be decrypted, and it turns out they can, quite easily, with a little PowerShell. Today I needed to find a password for a certain account I had used before (but had forgotten), and I remembered that I had stored the credentials in the Remote Desktop Connection Manager, Microsoft’s free RD tool.
data:image/s3,"s3://crabby-images/26c2f/26c2fdc588a11a8b121fe7a3c308e9fe2b4194ea" alt="Sysinternals rdcman"