python gnupg.encrypt:没有错误但没有加密数据或文件
在
Windows 7 w /
Python 2.7和GPG4Win v2.2.0上使用python-gnupg v0.3.5
test_gnupg.py导致2次失败:
解决方法
好吧,我终于开始研究这个并从命令行获得基本加密.这是一个用于加密从命令行输入的数据的示例:
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() 我这的工作都干完了! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |