今天尝试实现了利用python,编写程序来发送邮件,如下为实现过程:python
一:关于邮件传输的简介安全
SMTP (Simple Mail Transfer Protocol)
邮件传送代理 (Mail Transfer Agent,MTA) 程序使用SMTP协议来发送电邮到接收者的邮件服务器。SMTP协议只能用来发送邮件,不能用来接收邮件。大多数的邮件发送服务器 (Outgoing Mail Server) 都是使用SMTP协议。SMTP协议的默认TCP端口号是25。服务器
SMTP协议的一个重要特色是它可以接力传送邮件。它工做在两种状况下:一是电子邮件从客户机传输到服务器;二是从某一个服务器传输到另外一个服务器。函数
POP3 (Post Office Protocol) & IMAP (Internet Message Access Protocol)
POP协议和IMAP协议是用于邮件接收的最多见的两种协议。几乎全部的邮件客户端和服务器都支持这两种协议。post
POP3协议为用户提供了一种简单、标准的方式来访问邮箱和获取电邮。使用POP3协议的电邮客户端一般的工做过程是:链接服务器、获取全部信息并保存在用户主机、从服务器删除这些消息而后断开链接。POP3协议的默认TCP端口号是110。ui
IMAP协议也提供了方便的邮件下载服务,让用户能进行离线阅读。使用IMAP协议的电邮客户端一般把信息保留在服务器上直到用户显式删除。这种特性使得多个客户端能够同时管理一个邮箱。IMAP协议提供了摘要浏览功能,可让用户在阅读完全部的邮件到达时间、主题、发件人、大小等信息后再决定是否下载。IMAP协议的默认TCP端口号是143。编码
邮件格式 (RFC 2822)
每封邮件都有两个部分:邮件头和邮件体,二者使用一个空行分隔。spa
邮件头每一个字段 (Field) 包括两部分:字段名和字段值,二者使用冒号分隔。有两个字段须要注意:From和Sender字段。From字段指明的是邮件的做者,Sender字段指明的是邮件的发送者。若是From字段包含多于一个的做者,必须指定Sender字段;若是From字段只有一个做者而且做者和发送者相同,那么不该该再使用Sender字段,不然From字段和Sender字段应该同时使用。.net
邮件体包含邮件的内容,它的类型由邮件头的Content-Type字段指明。RFC 2822定义的邮件格式中,邮件体只是单纯的ASCII编码的字符序列。debug
MIME (Multipurpose Internet Mail Extensions) (RFC 1341)
MIME扩展邮件的格式,用以支持非ASCII编码的文本、非文本附件以及包含多个部分 (multi-part) 的邮件体等。
二:python模块
一、smtplib模块
smtplib.SMTP([host[, port[, local_hostname[, timeout]]]])
SMTP类构造函数,表示与SMTP服务器之间的链接,经过这个链接能够向smtp服务器发送指令,执行相关操做(如:登录、发送邮件)。全部参数都是可选的。
host:smtp服务器主机名
port:smtp服务的端口,默认是25;若是在建立SMTP对象的时候提供了这两个参数,在初始化的时候会自动调用connect方法去链接服务器。
smtplib模块还提供了SMTP_SSL类和LMTP类,对它们的操做与SMTP基本一致。
smtplib.SMTP提供的方法:
SMTP.set_debuglevel(level):设置是否为调试模式。默认为False,即非调试模式,表示不输出任何调试信息。
SMTP.connect([host[, port]]):链接到指定的smtp服务器。参数分别表示smpt主机和端口。注意: 也能够在host参数中指定端口号(如:smpt.yeah.net:25),这样就不必给出port参数。
SMTP.docmd(cmd[, argstring]):向smtp服务器发送指令。可选参数argstring表示指令的参数。
SMTP.helo([hostname]) :使用"helo"指令向服务器确认身份。至关于告诉smtp服务器“我是谁”。
SMTP.has_extn(name):判断指定名称在服务器邮件列表中是否存在。出于安全考虑,smtp服务器每每屏蔽了该指令。
SMTP.verify(address) :判断指定邮件地址是否在服务器中存在。出于安全考虑,smtp服务器每每屏蔽了该指令。
SMTP.login(user, password) :登录到smtp服务器。如今几乎全部的smtp服务器,都必须在验证用户信息合法以后才容许发送邮件。
SMTP.sendmail(from_addr, to_addrs, msg[, mail_options, rcpt_options]) :发送邮件。这里要注意一下第三个参数,msg是字符串,表示邮件。咱们知道邮件通常由标题,发信人,收件人,邮件内容,附件等构成,发送邮件的时候,要注意msg的格式。这个格式就是smtp协议中定义的格式。
SMTP.quit() :断开与smtp服务器的链接,至关于发送"quit"指令。
2.Python email模块
class email.message.Message
__getitem__,__setitem__实现obj[key]形式的访问。
Msg.attach(playload): 向当前Msg添加playload。
Msg.set_playload(playload): 把整个Msg对象的邮件体设成playload。
Msg.add_header(_name, _value, **_params): 添加邮件头字段。
class email.mime.base.MIMEBase(_maintype, _subtype, **_params)
全部MIME类的基类,是email.message.Message类的子类。
class email.mime.multipart.MIMEMultipart()
在3.0版本的email模块 (Python 2.3-Python 2.5) 中,这个类位于email.MIMEMultipart.MIMEMultipart。
这个类是MIMEBase的直接子类,用来生成包含多个部分的邮件体的MIME对象。
class email.mime.text.MIMEText(_text)
使用字符串_text来生成MIME对象的主体文本。
三:实例
根据以上介绍的模块,能够实现邮件发送的代码以下:
(本例使用的为163邮箱,其SMTP服务器地址为smtp.163.com,端口号:25)
#! /usr/bin/env python
import smtplib
from email.mime.text import MIMEText
mailto_list=['xxxx@xxx.com'] #收件人(列表)
mail_host="smtp.163.com"
mail_user="name" #用户名mail_pass="pwd"
mail_postfix="postfix"def send_mail(to_list,sub,content):
me="hello"+"<"+mail_user+"@"+mail_postfix+">"
msg = MIMEText(content,_subtype='plain')
msg['Subject'] = sub
msg['From'] = me
msg['To'] = ";".join(to_list) #将收件人列表以‘;’分隔
try:
server = smtplib.SMTP()
server.connect(mail_host)
server.login(mail_user,mail_pass)
server.sendmail(me, to_list, msg.as_string())
server.close()
return True
except Exception, e:
print str(e)
return False
for i in range(100):
if send_mail(mailto_list,"hello","haha!"): #邮件主题:hello,邮件内容:haha!print "done!" else: print "failed!"