在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
''
Run Code Online (Sandbox Code Playgroud)
encrypt_file()给出相同的结果,没有任何反应,没有错误.我对此并不是特别精明,但似乎如果我有数据和公钥,这应该是死的简单.我有一个可怕的时间试图确定什么是错误的,因为我看到没有任何日志文件,我尝试这个时没有错误.
我怎样才能确定这里出了什么问题?我在StackOverflow,http: //pythonhosted.org/python-gnupg/#getting-started 以及python-gnupg的google组中已经阅读了很多我能找到的内容.
另外,为什么我首先要有2套独立的钥匙圈?
编辑:澄清有2套独立的发布和限制
编辑2:下面的答案有助于导致实际问题.gnupg.GPG()构造函数正在设置包含'no-tty'的gpg命令行选项,调用gnupg.GPG(options ='')可以解决问题并成功加密数据和文件.
我确定我做了一些简单的错误,但我不能为我的生活弄清楚如何将"IsRead"属性设置为true.这是我的流程的最后一步,它获取了一个过滤的消息列表,并存储和处理任何附件.
据该文档"IsRead"是可写的:http://msdn.microsoft.com/office%5Coffice365%5CAPi/complex-types-for-mail-contacts-calendar#ResourcesMessage
我正在使用python 2.7和请求模块:
# once file acquired mark the email as read
params = {'IsRead':'True'}
base_email_url = u'https://outlook.office365.com/api/v1.0/me/messages/{0}'.format( msgId )
response = requests.patch(base_email_url, params, auth=(email,pwd))
log.debug( response )
Run Code Online (Sandbox Code Playgroud)
回复的反应如下:
{"error":{"code":"ErrorInvalidRequest","message":"Cannot read the request body."}}
Run Code Online (Sandbox Code Playgroud)
我的要求有什么问题?