在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
直接使用go-smtp包 ,为了防止乱码 , 主题subject进行了base64编码 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 如果发送失败 , 可以检测一下服务器是否允许访问外网25端口 , 一般腾讯云或者阿里云可能会封闭了访问25端口 , 并且不允许使用本机搭建的smtp服务进行发送 , 防止垃圾邮件泛滥 可以使用telnet smtp.sina.cn 25 这样的命令检测是否允许访问25端口 现在邮箱都是使用授权码进行验证的 , 注意是和登录密码有区别的 , 授权码一般在设置里面开启 , 只能重置生成不能修改 SendSmtp("smtp.sina.cn:25","[email protected]","xxxxx",[]string{"[email protected]"},"你好","邮件")
|
请发表评论