我正在使用 go-smtp 尝试向自己发送电子邮件: https: //github.com/emersion/go-smtp auth := sasl.NewPlainClient("", USERNAME, PASSWORD) to := []string{USERNAME} msg := strings.NewReader("To: " + USERNAME + "\r\n" + "Subject: testing golang go-smtp!\r\n" + "\r\n" + "This is the email body.\r\n") err := smtp.SendMail(SERVER_HOST + ":" + SERVER_PORT, auth, USERNAME, to, msg) if err != nil { log.Fatal(err) }输出为:EOF 退出状态 1我正在连接到 smtp.gmail.com:465 并且可以通过 Thunderbird 发送电子邮件。感谢您的帮助。沃尔特
2 回答
慕无忌1623718
TA贡献1744条经验 获得超4个赞
请查看此处的“配置选项”部分https://support.google.com/a/answer/176600?hl=en。它提到 Gmail 在端口 465 上对 SMTP 服务器使用 SSL,对端口 587 使用 TLS。要解决您的问题,您可以使用端口 587,因为该函数在内部进行调用,smtp.SendMail()
使用net.Dial()
纯 TCP 来发送邮件流量,并调用在此过程中稍后启动 STARTTLS。
如果您想使用端口 465,这里有一个很好的示例,适用于使用 SSL 发送电子邮件。
https://gist.github.com/chrisgillis/10888032
正如上面链接中提到的,这两种方法之间的主要区别在于,在 SSL 中,TLS 连接从一开始就建立,而如果您使用端口 587,则连接通过纯 TCP 启动,无需加密。
呼啦一阵风
TA贡献1802条经验 获得超6个赞
我也遇到了这个问题,go-smtp SendMail 在客户端问候中使用“localhost”。我相信 gmail 服务器可以拒绝“EHLO localhost”作为可能的 DOS 攻击。在内部,您会看到 EHLO 的第一个错误响应是“稍后重试”,然后是 EHLO 重试时的 EOF。使用更独特的名称来表示客户端问候,似乎不会被拒绝。但是,这意味着您不能依赖预设的“SendMail”功能来中继 smtp.gmail.com
- 2 回答
- 0 关注
- 651 浏览
添加回答
举报
0/150
提交
取消