概述
test_gnupg.py导致2次失败:
Test that searching for keys works … FAIL
Doctest: gnupg.GPG.recv_keys … FAIL
每个位置都有2个密钥环(每个密钥环中包含密码和密钥):
under the GPGHome directory (C:\Program Files (x86)\GNU\GnuPG)
under the user profile(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套独立的发布和调整
编辑2:
以下答案有助于解决实际问题.
gnupg.GPG()构造函数正在设置包含’no-tty’的gpg命令行选项,调用gnupg.GPG(options =”)可以解决问题并成功加密数据和文件.
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()
我这的工作都干完了!
总结
以上是编程之家为你收集整理的python gnupg.encrypt:没有错误但没有加密数据或文件全部内容,希望文章能够帮你解决python gnupg.encrypt:没有错误但没有加密数据或文件所遇到的程序开发问题。
如果您也喜欢它,动动您的小指点个赞吧