2

我正在尝试散列密码以转储到 .rdp 文件中。我发现了一个网站(或多或少)在这里展示了如何做到这一点,但它在 3.1 中不起作用。

在 2.5.4 我得到这个:

>>> import win32crypt
>>> import binascii
>>> pwdHash = win32crypt.CryptProtectData(u"password",u'psw',None,None,None,0)
>>> print str(binascii.hexlify(pwdHash)).upper()
01000000D08C9DDF0115D1118C7A00C04FC297EB010000007E9E... blah, blah blah

在 3.1 中,我得到了这个(3.1 中的一切都是 unicode,所以只需放弃 u”,对吗?):

>>> pwdHash = win32crypt.CryptProtectData("password",'psw',None,None,None,0)
Traceback (most recent call last):
  File "<pyshell#19>", line 1, in <module>
    pwdHash = win32crypt.CryptProtectData("password",'psw',None,None,None,0)
TypeError: expected an object with a buffer interface

好的,我以前见过这个错误,通常这意味着我需要先转换为字节,所以:

>>> pwdHash = win32crypt.CryptProtectData("password".encode(),'psw',None,None,None,0)
>>> print(str(binascii.hexlify(pwdHash)).upper())
B'01000000D08C9DDF0115D1118C7A00C04FC297EB010000007E9E... blah, blah, blah
>>>

看起来一切都很好,但是当您将该十六进制值转储到 .rdp 文件中时,这不起作用,我只能假设这是因为它不是 unicode 字符串“密码”的十六进制密码,而是十六进制密码字节“密码”。我尝试了 .decode() 但这正是您所期望的并将十六进制加密字节转换为字符串,它不会为您提供原始 unicode 字符串的十六进制加密字符串。

我已经疯狂地搜索有关 win32crypt.CryptProtectData 的任何信息,但我找不到任何有用的信息来说明为什么它现在需要字节或缓冲区对象而不是字符串。

有人可以帮忙吗?
(或者有人知道将密码输入远程桌面会话的更简单方法吗?我通过 Python 以编程方式打开?呵呵)

4

1 回答 1

2

改用 "password".encode('utf-16-le') 。

于 2011-03-30T12:35:00.000 回答