小编tor*_*rpy的帖子

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

在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 ='')可以解决问题并成功加密数据和文件.

python encryption gnupg

5
推荐指数
1
解决办法
5689
查看次数

Office 365 REST API(Python)将电子邮件标记为已读

我确定我做了一些简单的错误,但我不能为我的生活弄清楚如何将"IsRead"属性设置为true.这是我的流程的最后一步,它获取了一个过滤的消息列表,并存储和处理任何附件.

据该文档"IsRead"是可写的:http://msdn.microsoft.com/office%5Coffice365%5CAPi/complex-types-for-mail-contacts-calendar#ResourcesMessage

http://msdn.microsoft.com/office%5Coffice365%5CAPi/mail-rest-operations#MessageoperationsUpdatemessages

我正在使用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)

我的要求有什么问题?

python rest python-2.7 office365

5
推荐指数
1
解决办法
1892
查看次数

标签 统计

python ×2

encryption ×1

gnupg ×1

office365 ×1

python-2.7 ×1

rest ×1