Python之SMTP詳解
這段代碼解釋了SMTP在python中的基本應用。
- 獲得服務器的特性,如:允許發送的郵件大小。
- 查看服務器是否支持SSL和TLS安全傳輸。
- 查看在發送郵件之前是否需要認證。 </ol>
#!/usr/bin/env python #-*-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 = """ TO: %s From: %s Subject: Test Message from SMTP_mail.py Hello ,This a simple SMTP_mail example. """ % (','.join(toaddr),fromaddr) def get_size(): """獲得服務器允許發送郵件的大小""" 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('size'): #獲得服務器允許發送郵件的大小 print "Maxinum message size is ",s.esmtp_features['size'] if len(message) > int(s.esmtp_features['size']): print "Message too large;aborting." sys.exit(2) 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) 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 == "__mian__": get_size() ssl_tls() auth_login()
本文由用戶 fmms 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!