好吧,我终于开始研究这个,并从命令行获得了基本的加密功能。这是一个对从命令行输入的数据进行加密的示例:
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 装甲加密数据打印到标准输出。
编辑:我不确定,但我怀疑您的代码失败的原因是由于使用了收件人密钥 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 2.7,对于 Python 3,您需要修改 raw_input() 行以使用 input() 代替。