直接使用go-smtp包 ,爲了防止亂碼 , 主題subject進行了base64編碼git
import ( "encoding/base64" "github.com/emersion/go-sasl" "github.com/emersion/go-smtp" "strings" ) func SendSmtp(server string, from string, password string, to []string, subject string, body string) error { auth := sasl.NewPlainClient("", from, password) subjectBase := base64.StdEncoding.EncodeToString([]byte(subject)) msg := strings.NewReader( "From: " + from + "\r\n" + "To: " + strings.Join(to, ",") + "\r\n" + "Subject: =?UTF-8?B?" + subjectBase + "?=\r\n" + "\r\n" + body + "\r\n") err := smtp.SendMail(server, auth, from, to, msg) if err != nil { return err } return nil }
使用的時候 , 注意端口號要加上 ,端口號是25 github
若是發送失敗 , 能夠檢測一下服務器是否容許訪問外網25端口 , 通常騰訊雲或者阿里雲可能會封閉了訪問25端口 , 而且不容許使用本機搭建的smtp服務進行發送 , 防止垃圾郵件氾濫服務器
能夠使用telnet smtp.sina.cn 25 這樣的命令檢測是否容許訪問25端口阿里雲
如今郵箱都是使用受權碼進行驗證的 , 注意是和登陸密碼有區別的 , 受權碼通常在設置裏面開啓 , 只能重置生成不能修改編碼
SendSmtp("smtp.sina.cn:25","taoshihan1@sina.com","xxxxx",[]string{"xxxx@qq.com"},"你好","郵件")spa