昨天,IT部门对Exchange服务器进行了更改。我以前能够使用imaplib
从服务器获取消息。但现在看来他们已经关闭了我正在使用的身份验证机制。从下面的输出中,看起来服务器现在只支持NTLM身份验证。
>>> from imaplib import IMAP4_SSL
>>> s = IMAP4_SSL("my.imap.server")
>>> s.capabilities
('IMAP4', 'IMAP4REV1', 'IDLE', 'LOGIN-REFERRALS', 'MAILBOX-REFERRALS',
'NAMESPACE', 'LITERAL+', 'UIDPLUS', 'CHILDREN', 'AUTH=NTLM')
>>> s.login("username", "password")
...
imaplib.error: Clear text passwords have been disabled for this protocol.
问题:
连接到imap服务器的进程在Linux,BTW上运行。所以我无法使用pywin32。
修改
我能够弄清楚1.我自己。但是如何2:IMAP over SSL中的明文密码不是安全问题,是吗?
答案 0 :(得分:4)
我能够使用python-ntlm项目。
python-ntlm
实现HTTP的NTLM身份验证。通过扩展此项目很容易为IMAP添加NTLM身份验证。
我已添加了a patch for the project。