我正在尝试通过标准库SMTP包发送邮件,并且它在10分钟内什么都没做,然后由于无用的文件结尾错误而失败,我无法理解。

// excerpt from the calling function
// --- snip ---
if e := mailNotify(board, validPosts, ipMinusPort, delTime); e != nil {
    errorPage(w, tmpl, "Contact Administrator",
        "Email notification failed, please contact archive admin.")
    log.Println("ERROR: Failed to send notification email: " + e.Error())
}
// --- snip ---

func mailNotify(board *config.Board, validPosts []int64,
                        ip string, delTime time.Time) error {

    addresses := strings.Split(board.NotifyAddr, ",")
    if len(addresses) < 1 {
        return nil
    }

    msg := new(bytes.Buffer)
    type values struct {
        IP      string
        Posts   []int64
        DelTime time.Time
    }
    t.ExecuteTemplate(msg, "post_reported", &values{ip, validPosts, delTime})
    auth:= smtp.PlainAuth("", board.NotifyAddr, board.NotifyPass,
        strings.Split(board.SMTPServer, ":")[0])
    return smtp.SendMail(board.SMTPServer, auth,
        board.FromEmail, addresses, msg.Bytes())
}

记录的确切消息是:



我已经log.Printf调试了此功能,并验证了此时发送的值是否有效。电子邮件地址是gmail.com上的真实地址,密码正确,board.SMTPServersmtp.googlemail.com:465。我试过将msg.Bytes()的结果存储在一个单独的变量中,并采用长度来确保它正在生成要发送的字节数组,并且长度确实为非零。我猜测EOF正在从标准库中比SendMail函数本身更深的地方冒出来,但我不知道它在哪里阻塞,我不知道该怎么做。

最佳答案

Gmail的端口465用于通过TLS进行连接,但是SendMail需要使用普通的旧TCP。尝试改为连接到端口587。可用时,SendMail将自动升级到TLS(在本例中就是这种情况)。

关于使用EOF 10分钟后,smtp.SendMail失败,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11662017/

10-13 07:51