綜合網絡上的文章以及自己的實驗,在python的IDEL下成功的通過SMTP發送出去了郵件。現將過程記錄如下:
一、準備工作:
1、安裝好python3.x
2、擁有一個支持smtp服務的郵箱,我是用的126的郵箱 網易和騰訊的郵箱的密碼現在都變爲授權碼登錄。需要蒐集這些信息:SMTP服務器地址,你的郵箱賬號,授權碼。
二、思路
發送HTML和帶附件的郵件,我們要用到先把html文件組合到一起,做爲一個整體。可以理解爲作爲一個郵包。然後通過SMTP協議傳輸出去。這個SMTP是傳輸協議。那麼我們用python只需要操作創建連接和發送的部分代碼。下面把代碼貼出來
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart from email.mime.application import MIMEApplication import traceback my_sender = '發件人的郵箱地址' my_passwd = '發件人的密碼,網易、騰訊是用授權碼' my_user = '收件人的郵箱地址' my_smtp_host='smtp.126.com' #126的smtp服務器地址 def mail(): ret = True try: #開始打包郵件 msg=MIMEMultipart() msg['From']=formataddr(['發件人郵件暱稱',my_sender])#設置發件人 msg['To'] = formataddr(['收件人郵件暱稱',my_user])#設置收件人 msg['Subject']='這個是郵件的主題' #下面是正文內容 pureText = MIMEText(open('release-notes.html', 'rb').read(),'html','utf-8') #隨便找的html文件,後面兩個參數是告訴程序以html格式和utf-8字符 msg.attach(pureText) #下面是各種類型的附件了 # 首先是xlsx類型的附件 xlsxpart = MIMEApplication(open('test.xlsx', 'rb').read()) xlsxpart.add_header('Content-Disposition', 'attachment', filename='test.xlsx') msg.attach(xlsxpart) # jpg類型的附件 jpgpart = MIMEApplication(open('2.jpg', 'rb').read()) jpgpart.add_header('Content-Disposition', 'attachment', filename='2.jpg') msg.attach(jpgpart) #下面開始發送了 server=smtplib.SMTP(my_smtp_host,25)#smtp服務器端口默認是25 # server.set_debuglevel(1)# 設置爲調試模式,就是在會話過程中會有輸出信息 server.login(my_sender,my_passwd) server.sendmail(my_sender,[my_user,],msg.as_string()) server.quit() except Exception : ret = False return ret ret = mail() if ret: print("ok") else: print('failed')
從上面的註釋可以看出來,大體的步驟了。下面是收到的郵件,有圖有真相
下面的Gradle Release Notes 是我隨便找的html文件讀出來的內容
備註:
release-notes.html test.xlsx 2.jpg 都是和代碼在同一目錄裏面的
有問題,可以留言討論