加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python gnupg.encrypt:没有错误但没有加密数据或文件

发布时间:2020-12-16 21:31:57 所属栏目:Python 来源:网络整理
导读:在 Windows 7 w / Python 2.7和GPG4Win v2.2.0上使用python-gnupg v0.3.5 test_gnupg.py导致2次失败: Test that searching for keys works … FAIL Doctest: gnupg.GPG.recv_keys … FAIL 每个位置都有2个密钥环(每个密钥环中包含密码和密钥): under the G
在 Windows 7 w / Python 2.7和GPG4Win v2.2.0上使用python-gnupg v0.3.5

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)GNUGnuPG)

under the user profile(C:UsersAppDataRoaminggnupg)

如果我创建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()

我这的工作都干完了!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读