这段代码解释了SMTP在python中的基本应用
查看服务器是否支持SSL和TLS安全传输。
查看在发送邮件之前是否需要认证。
1、问题:
authentication failed :(534,'5.7.12 SMTP access disabled')
解决方法:
邮箱账户设置——》邮件服务器——》勾选SMTP需要服务器验证——》选择使用与POP3服务器相同信息——》完成。
如图所示:
POP3/SMTP服务点击开启就好。
实验代码如下:
#!/usr/bin/env python
# -*- coding: cp936 -*-
#-*-coding = UTF-8-*-
#SMTP_email.py
#auth@:xfk
#date@:2012-04-30
import sys
import smtplib
import socket
from getpass import getpass
if len(sys.argv) < 4:
print "[*]usage:%s server fromaddr toaddr " % sys.argv[0]
sys.exit(1)
server = sys.argv[1]
fromaddr = sys.argv[2]
toaddr = sys.argv[3]
message = """
我是欢欢,利用Python媒介发给未来自己的一封信.....
TO: %s
From: %s
Subject: Test Message from SMTP_mail.py
Hello ,This a simple SMTP_mail example.
""" % (','.join(toaddr),fromaddr)
def ssl_tls():
"""使用SSL安全套阶层和TLS安全传输层进行邮件传输,确保密码在传输中的安全"""
try:
s = smtplib.SMTP(server) #连接到服务器
code = s.ehlo()[0] #返回服务器的特性
usesesmtp = 1
if not (200 <= code <=299): #在200到299之间都是正确的返回值
usesesntp = 0
code = s.helo()[0]
if not (200 <= code <=299):
raise SMTPHeloError(code,resp)
if usesesmtp and s.has_extn('starttls'): #查看服务器是否支持TLS
print "Negotiating TLS......"
s.starttls()
code = s.ehlo()[0]
if not (200 <= code <=299): #在支持TLS的服务器上是否连接回话成功
print "Couldn't EHLO after STARTTLS."
sys.exit(5)
print "Using TLS connection."
else:
print "Server does not suport TLS; using normal connection."
s.sendmail(fromaddr,toaddr,message) #如果连接TLS成功则使用加密传输;若连接TLS出错则使用普通的传输
except(socket.gaierror,socket.error,socket.herror,smtplib.SMTPException),e:
print "***Your message may not have been sent!"
print e
sys.exit(1)
else:
print "***Message successful sent to %d recipient(s)" % len(toaddr)
def auth_login():
"""当发送邮件时,服务器需要验证,则输入用户名密码方可发送邮件"""
sys.stdout.write("Enter username: ")
username = sys.stdin.readline().strip()
password = getpass("Enter password: ")
try:
s = smtplib.SMTP(server) #连接到服务器
code = s.ehlo()[0] #返回服务器的特性
usesesmtp = 1
if not (200 <= code <=299): #在200到299之间都是正确的返回值
usesesntp = 0
code = s.helo()[0]
if not (200 <= code <=299):
raise SMTPHeloError(code,resp)
if usesesmtp and s.has_extn('auth'): #查看服务器是否支持认证
print "Using Authentication connect."
try:
s.login(username,password)
except smtplib.SMTPException,e:
print "Authentication failed:",e
sys.exit(1)
else:
print "Server does not suport Authentication; using normal connect."
s.sendmail(fromaddr,toaddr,message) #如果支持认证则输入用户名密码进行认证;不支持则使用普通形式进行传输
except(socket.gaierror,socket.error,socket.herror,smtplib.SMTPException),e:
print "***Your message may not have been sent!"
print e
sys.exit(1)
else:
print "***Message successful sent to %d recipient(s)" % len(toaddr)
if __name__ == "__main__":
auth_login()
ssl_tls()
结果为:
新浪邮箱显示:
补充:
什么是POP3、SMTP和IMAP?
POP3
POP3是Post Office Protocol 3的简称,即邮局协议的第3个版本,它规定怎样将个人计算机连接到Internet的邮件服务器和下载电子邮件的电子协议。它是因特网电子邮件的第一个离线协议标准,POP3允许用户从服务器上把邮件存储到本地主机(即自己的计算机)上,同时删除保存在邮件服务器上的邮件,而POP3服务器则是遵循POP3协议的接收邮件服务器,用来接收电子邮件的。(与IMAP有什么区别?)
SMTP
SMTP 的全称是“Simple Mail Transfer Protocol”,即简单邮件传输协议。它是一组用于从源地址到目的地址传输邮件的规范,通过它来控制邮件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。SMTP 服务器就是遵循 SMTP 协议的发送邮件服务器。
SMTP 认证,简单地说就是要求必须在提供了账户名和密码之后才可以登录 SMTP 服务器,这就使得那些垃圾邮件的散播者无可乘之机。
增加 SMTP 认证的目的是为了使用户避免受到垃圾邮件的侵扰。
网易邮箱已经默认开启 POP3/SMTP/IMAP 服务,方便您可以通过电脑客户端软件更好地收发邮件,如果关闭可以通过以下方式开启:
请登录163邮箱,点击页面正上方的“设置”,再点击左侧上“POP3/SMTP/IMAP”,其中“开启SMTP服务”是系统默认勾选开启的。您可勾选图中另两个选项,点击确定,即可开启成功。不勾选图中两个选项,点击确定,可关闭成功。