21.14. poplib
— POP3 协议客户端¶
源代码: Lib/poplib.py
本模块定义了一个 POP3
类,该类封装了到 POP3 服务器的连接过程,并实现了 RFC 1939 中定义的协议。POP3
类同时支持 RFC 1939 中最小的和可选的命令集。POP3
类还支持在 RFC 2595 中引入的 STLS
命令,用于在已建立的连接上启用加密通信。
本模块额外提供一个 POP3_SSL
类,在连接到 POP3 服务器时,该类为使用 SSL 作为底层协议层提供了支持。
注意,尽管 POP3 具有广泛的支持,但它已经过时。POP3 服务器的实现质量差异很大,而且大多很糟糕。如果邮件服务器支持 IMAP,则最好使用 imaplib.IMAP4
类,因为 IMAP 服务器一般实现得更好。
poplib
模块提供了两个类:
-
class
poplib.
POP3
(host, port=POP3_PORT[, timeout])¶ 本类实现实际的 POP3 协议。实例初始化时,连接就会建立。如果省略 port,则使用标准 POP3 端口(110)。可选参数 timeout 指定连接尝试的超时时间(以秒为单位,如果未指定超时,将使用全局默认超时设置)。
-
class
poplib.
POP3_SSL
(host, port=POP3_SSL_PORT, keyfile=None, certfile=None, timeout=None, context=None)¶ 一个
POP3
的子类,它使用经 SSL 加密的套接字连接到服务器。如果端口 port 未指定,则使用 995,它是标准的 POP3-over-SSL 端口。timeout 的作用与POP3
构造函数中的相同。context 是一个可选的ssl.SSLContext
对象,该对象可以将 SSL 配置选项、证书和私钥打包放入一个单独的(可以长久存在的)结构中。请阅读 安全考量 以获取最佳实践。keyfile 和 certfile 是可以代替 context 的传统方案,它们可以分别指向 PEM 格式的私钥和证书链文件,用于进行 SSL 连接。
3.2 版更變: 添加了 context 参数。
3.4 版更變: 本类现在支持通过
ssl.SSLContext.check_hostname
和 服务器名称提示 (参阅ssl.HAS_SNI
)进行主机名检查。3.6 版後已棄用: keyfile 和 certfile 已弃用并转而推荐 context。 请改用
ssl.SSLContext.load_cert_chain()
或让ssl.create_default_context()
为你选择系统所信任的 CA 证书。
定义了一个异常,它是作为 poplib
模块的属性定义的:
也參考
imaplib
模块标准的 Python IMAP 模块。
- 有关 Fetchmail 的常见问题
fetchmail POP/IMAP 客户端的“常见问题”收集了 POP3 服务器之间的差异和 RFC 不兼容的信息,如果要编写基于 POP 协议的应用程序,这可能会很有用。
21.14.1. POP3 对象¶
所有 POP3 命令均以同名的方法表示,小写,大多数方法返回的是服务器发送的响应文本。
POP3
实例具有下列方法:
-
POP3.
set_debuglevel
(level)¶ 设置实例的调试级别,它控制着调试信息的数量。默认值
0
不产生调试信息。值1
产生中等数量的调试信息,通常每个请求产生一行。大于或等于2
的值产生的调试信息最多,FTP 控制连接上发送和接收的每一行都将被记录下来。
-
POP3.
getwelcome
()¶ 返回 POP3 服务器发送的问候语字符串。
-
POP3.
user
(username)¶ 发送 user 命令,返回的响应应该指示需要一个密码。
-
POP3.
pass_
(password)¶ 发送密码,响应包括邮件数和邮箱大小。注意:在调用
quit()
前,服务器上的邮箱都是锁定的。
-
POP3.
apop
(user, secret)¶ 使用更安全的 APOP 身份验证登录到 POP3 服务器。
-
POP3.
rpop
(user)¶ 使用 RPOP 身份验证(类似于 Unix r-命令)登录到 POP3 服务器。
-
POP3.
stat
()¶ 获取邮箱状态。结果为 2 个整数组成的元组:
(message count, mailbox size)
。
-
POP3.
list
([which])¶ 请求消息列表,结果的形式为
(response, ['mesg_num octets', ...], octets)
。如果设置了 which,它表示需要列出的消息。
-
POP3.
retr
(which)¶ 检索编号为 which 的整条消息,并设置其已读标志位。结果的形式为
(response, ['line', ...], octets)
。
-
POP3.
dele
(which)¶ 将编号为 which 的消息标记为待删除。在多数服务器上,删除操作直到 QUIT 才会实际执行(主要例外是 Eudora QPOP,它在断开连接时执行删除,故意违反了 RFC)。
-
POP3.
rset
()¶ 移除邮箱中的所有待删除标记。
-
POP3.
noop
()¶ 什么都不做。可以用于保持活动状态。
-
POP3.
quit
()¶ 登出:提交更改,解除邮箱锁定,断开连接。
-
POP3.
top
(which, howmuch)¶ 检索编号为 which 的消息,范围是消息头加上消息头往后数 howmuch 行。结果的形式为
(response, ['line', ...], octets)
。本方法使用 POP3 TOP 命令,不同于 RETR 命令,它不设置邮件的已读标志位。不幸的是,TOP 在 RFC 中说明不清晰,且在小众的服务器软件中往往不可用。信任并使用它之前,请先手动对目标 POP3 服务器测试本方法。
-
POP3.
uidl
(which=None)¶ 返回消息摘要(唯一 ID)列表。如果指定了 which,那么结果将包含那条消息的唯一 ID,形式为
'response mesgnum uid
,如果未指定,那么结果为列表(response, ['mesgnum uid', ...], octets)
。
-
POP3.
utf8
()¶ 尝试切换至 UTF-8 模式。成功则返回服务器的响应,失败则引发
error_proto
异常。在 RFC 6856 中有说明。3.5 版新加入.
-
POP3.
stls
(context=None)¶ 在活动连接上开启 TLS 会话,在 RFC 2595 中有说明。仅在用户身份验证前允许这样做。
context 参数是一个
ssl.SSLContext
对象,该对象可以将 SSL 配置选项、证书和私钥打包放入一个单独的(可以长久存在的)结构中。请阅读 安全考量 以获取最佳实践。此方法支持通过
ssl.SSLContext.check_hostname
和 服务器名称指示 (参见ssl.HAS_SNI
) 进行主机名检查。3.4 版新加入.
POP3_SSL
实例没有额外方法。该子类的接口与其父类的相同。
21.14.2. POP3 示例¶
以下是一个最短示例(不带错误检查),该示例将打开邮箱,检索并打印所有消息:
import getpass, poplib
M = poplib.POP3('localhost')
M.user(getpass.getuser())
M.pass_(getpass.getpass())
numMessages = len(M.list()[1])
for i in range(numMessages):
for j in M.retr(i+1)[1]:
print(j)
模块的最后有一段测试,其中包含的用法示例更加广泛。