go-smtp,无法通过 gmail 发送电子邮件,收到 EOF

go-smtp, unable to send email through gmail, getting EOF

我正在使用 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)
    }

输出是: 结束符 退出状态 1

我正在连接到 smtp.gmail.com:465 并且可以通过 thunderbird 发送电子邮件。

感谢您的帮助。

沃尔特

在此处查看 "Configuration options" 部分 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

上述link中也提到的两种方法之间的主要区别在于,在 SSL 中,TLS 连接是从一开始就建立的,而如果您使用端口 587,连接将通过普通 TCP 开始,而无需加密。

我也有这个问题,go-smtp SendMail 在客户端 hello 中使用“localhost”。我相信 gmail 服务器可以拒绝“EHLO localhost”作为可能的 DOS 攻击。在内部,您会看到对 EHLO 的第一个错误响应是“稍后重试”,然后是 EHLO 重试时的 EOF。为客户问候使用更独特的名称,似乎不会被拒绝。但是,这些意味着您不能依赖固定的“SendMail”功能来中继 smtp.gmail.com