在Windows 7 w / Python 2.7和GPG4Win v2.2.0上使用python-gnupg v0.3.5
test_gnupg.py导致2次失败:
测试搜索密钥是否有效......失败
Doctest:gnupg.GPG.recv_keys ...失败
每个位置都有2个密钥环(每个位置都有密封和发布):
在GPGHome目录下(C:\ Program Files(x86)\ GNU \ GnuPG)
在用户个人资料下(C:\ Users \\ AppData \ Roaming \ gnupg)
如果我创建GPG实例并将密钥环文件路径设置为用户配置文件pubring.pgp,我会从GPG.list_keys()获得结果。如果我让它使用gpghome目录pubring.pgp我没有得到list_keys()的结果,因为该密钥环是空的。
因此,我指定用户配置文件密钥环并且我有一个密钥可以使用它是发生的事情:
>>>data = '1234 abcd 56678'
>>>fingerprint = u'<fingerprint>'
>>>enc = gpg.encrypt(data,fingerprint)
>>>enc.data
''
encrypt_file()给出相同的结果,没有任何反应,没有错误。我对此并不是特别精明,但似乎如果我有数据和公钥,这应该是死的简单。我有一个可怕的时间试图确定什么是错误的,因为我在任何地方看不到任何日志文件,我在尝试时没有错误。
我如何确定这里出了什么问题? 我已经在StackOverflow,http://pythonhosted.org/python-gnupg/#getting-started以及python-gnupg的google组中阅读了我能找到的所有内容。
另外,为什么我首先要有两套独立的钥匙圈?
编辑: 澄清有2套独立的发布和调整
编辑2: 以下答案有助于解决实际问题。 gnupg.GPG()构造函数正在设置包含'no-tty'的gpg命令行选项,调用gnupg.GPG(options ='')可以解决问题并成功加密数据和文件。
答案 0 :(得分:3)
好的,我终于开始研究这个并从命令行获得基本加密。这是一个用于加密从命令行输入的数据的示例:
import gnupg
gpg_home = "/path/to/gnupg/home"
gpg = gnupg.GPG(gnupghome=gpg_home)
data = raw_input("Enter data to encrypt: ")
rkey = raw_input("Enter recipient's key ID: ")
encrypted_ascii_data = gpg.encrypt(data, rkey)
print(encrypted_ascii_data)
将gpg_home更改为您要使用的两个GnuPG路径中的任何一个。第一个看起来像默认安装位置,第二个看起来特定于您的用户帐户。该脚本将提示加密一些文本和加密的密钥ID,然后将ASCII装甲加密数据打印到stdout。
编辑:我不确定,但我怀疑你的代码失败的原因是由于使用了收件人密钥ID的整个指纹,这是不必要的(我使用了0xLONG格式,其中的一个示例在我的个人资料),或者您调用了错误的GPG主目录。编辑2:这适用于加密文件并将输出写入同一目录中的文件,它将在* nix系统上正常工作。您将需要更改gpg_home,如上例所示:
import gnupg
gpg_home = "~/.gnupg"
gpg = gnupg.GPG(gnupghome=gpg_home)
data = raw_input("Enter full path of file to encrypt: ")
rkeys = raw_input("Enter key IDs separated by spaces: ")
savefile = data+".asc"
afile = open(data, "rb")
encrypted_ascii_data = gpg.encrypt_file(afile, rkeys.split(), always_trust=True, output=savefile)
afile.close()
我的工作已经完成! :)
BTW,这两个示例都使用Python 2.7,对于Python 3,您需要修改raw_input()行以改为使用input()。