直接使用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