go-smtp,无法通过gmail发送电子邮件,收到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)

    }

输出为:EOF 退出状态 1


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


感谢您的帮助。


沃尔特


Smart猫小萌
浏览 652回答 2
2回答

慕无忌1623718

请查看此处的“配置选项”部分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 启动,无需加密。

呼啦一阵风

我也遇到了这个问题,go-smtp SendMail 在客户端问候中使用“localhost”。我相信 gmail 服务器可以拒绝“EHLO localhost”作为可能的 DOS 攻击。在内部,您会看到 EHLO 的第一个错误响应是“稍后重试”,然后是 EHLO 重试时的 EOF。使用更独特的名称来表示客户端问候,似乎不会被拒绝。但是,这意味着您不能依赖预设的“SendMail”功能来中继 smtp.gmail.com
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go