13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

创新互联Python教程:smtpd—-SMTP服务器

smtpd —- SMTP 服务器

源代码: Lib/smtpd.py


该模块提供了几个类来实现 SMTP (电子邮件)服务器。

从版本 3.6 开始标记为过时,将在版本 3.12 中移除。: The smtpd module is deprecated (see PEP 594 for details). The aiosmtpd package is a recommended replacement for this module. It is based on asyncio and provides a more straightforward API.

有几个服务器的实现;一个是通用的无为实现,可以被重写,而另外两个则提供特定的邮件发送策略。

此外, SMTPChannel 可以被扩展以实现与 SMTP 客户端非常具体的交互行为。

该代码支持 RFC 5321 ,加上 RFC 1870 SIZE和 RFC 6531 SMTPUTF8 扩展。

Availability: not Emscripten, not WASI.

This module does not work or is not available on WebAssembly platforms wasm32-emscripten and wasm32-wasi. See WebAssembly platforms for more information.

SMTPServer 对象

class smtpd.SMTPServer(localaddr, remoteaddr, data_size_limit=33554432, map=None, enable_SMTPUTF8=False, decode_data=False)

新建一个 SMTPServer 对象,它会绑定到本机地址 localaddr。 它将把 remoteaddr 当作上游 SMTP 中继器。 localaddrremoteaddr 都应当是 (host, port) 元组。 该对象继承自 asyncore.dispatcher,因而会在实例化时将自己插入到 asyncore 的事件循环。

data_size_limit 指定将在 DATA 命令中被接受的最大字节数。 值为 None0 表示无限制。

map 是用于连接的套接字映射(初始为空的字典是适当的值)。 如果未指定则会使用 asyncore 全局套接字映射。

enable_SMTPUTF8 决定是否应当启用 SMTPUTF8 扩展(如 RFC 6531 所定义的。 默认值为 False。 当设为 True 时,会接受 SMTPUTF8 作为 MAIL 命令的形参并在被提供时将其传给 kwargs['mail_options'] 列表中的 process_message()。 decode_dataenable_SMTPUTF8 不可同时被设为 True

decode_data 指明 SMTP 事务的数据部分是否应当使用 UTF-8 来解码。 当 decode_dataFalse 时(默认值),服务器会声明 8BITMIME 扩展 (RFC 6152),接受来自 MAIL 命令的 BODY=8BITMIME 形参,并在该形参存在时将其传给 kwargs['mail_options'] 列表中的 process_message() 方法。 decode_dataenable_SMTPUTF8 不可同时被设为 True

3.4 新版功能: map 构造器参数。

在 3.5 版更改: localaddrremoteaddr 现在可以包含 IPv6 地址。

3.5 新版功能: decode_dataenable_SMTPUTF8 构造器形参,以及当 decode_dataFalse 时传给 process_message() 的 kwargs 形参。

在 3.6 版更改: decode_data 现在默认为 False

DebuggingServer 对象

class smtpd.DebuggingServer(localaddr, remoteaddr)

创建一个新的调试服务器。 参数是针对每个 SMTPServer。 消息将被丢弃,并在 stdout 上打印出来。

PureProxy 对象

class smtpd.PureProxy(localaddr, remoteaddr)

创建一个新的纯代理服务器。 参数是针对每个 SMTPServer。 一切都将被转发到 remoteaddr。 请注意运行此对象有很大的机会令你成为一个开放的中继站,所以需要小心。

SMTPChannel 对象

class smtpd.SMTPChannel(server, conn, addr, data_size_limit=33554432, map=None, enable_SMTPUTF8=False, decode_data=False)

创建一个新的 SMTPChannel 对象,该对象会管理服务器和单个 SMTP 客户端之间的通信。

connaddr 是针对下述的每个实例变量。

data_size_limit 指定将在 DATA 命令中被接受的最大字节数。 值为 None0 表示无限制。

enable_SMTPUTF8 确定 SMTPUTF8 扩展 (如 RFC 6531 所定义的) 是否应当被启用。 默认值为 Falsedecode_dataenable_SMTPUTF8 不能被同时设为 True

可以在 map 中指定一个字典以避免使用全局套接字映射。

decode_data 指明 SMTP 事务的数据部分是否应当使用 UTF-8 来解码。 默认值为 Falsedecode_dataenable_SMTPUTF8 不能被同时设为 True

要使用自定义的 SMTPChannel 实现你必须重载你的 SMTPServer 的 SMTPServer.channel_class。

在 3.5 版更改: 添加了 decode_dataenable_SMTPUTF8 形参。

在 3.6 版更改: decode_data 现在默认为 False

SMTPChannel 具有下列实例变量:

SMTPChannel 在接收到来自客户端的命令行时会通过发起调用名为 smtp_ 的方法来进行操作。 在基类 SMTPChannel 中具有用于处理下列命令(并对他们作出适当反应)的方法:

命令

所采取的行动

HELO

接受来自客户端的问候语,并将其存储在 seen_greeting 中。将服务器设置为基本命令模式。

EHLO

接受来自客户的问候并将其存储在 seen_greeting 中。将服务器设置为扩展命令模式。

NOOP

不采取任何行动。

QUIT

干净地关闭连接。

MAIL

接受 “MAIL FROM:” 句法并将所提供的地址保存为 mailfrom。 在扩展命令模式下,还接受 RFC 1870 SIZE 属性并根据 data_size_limit 的值作出适当返应。

RCPT

接受 “RCPT TO:” 句法并将所提供的地址保存在 rcpttos 列表中。

RSET

重置 mailfrom, rcpttos, 和 received_data ,但不重置问候语。

DATA

将内部状态设为 DATA 并将来自客户端的剩余行保存在 received_data 中直至接收到终止符 “\r\n.\r\n”

HELP

返回有关命令语法的最少信息

VRFY

返回代码252(服务器不知道该地址是否有效)

EXPN

报告该命令未实现。


当前题目:创新互联Python教程:smtpd—-SMTP服务器
网站地址:http://cdbrznjsb.com/article/cdcsgpd.html

其他资讯

让你的专属顾问为你服务