亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Golang SMTP 錯誤: 535 5.7.0 登錄名或密碼無效

Golang SMTP 錯誤: 535 5.7.0 登錄名或密碼無效

Go
當年話下 2022-09-05 10:22:07
我正在嘗試使用go創建電子郵件服務。當我嘗試通過gmail或office365代碼發送電子郵件時,工作正常,但當我嘗試通過自定義smtp發送電子郵件時,我得到“535 5.7.0無效的登錄名或密碼”錯誤。我知道用戶名和密碼是正確的,因為我正在與另一個python服務使用相同的密碼和用戶名,其他服務工作正常。我沒有任何自定義SMTP服務器的文檔,但我知道SMTP服務器使用TLS我嘗試了普通的身份驗證,gomailer,smtp。SendMail() 函數,沒有 startTLS,但沒有任何變化。這是我的代碼;func (m *Mail) sendMail(body, to, subject string) bool {env := common.GetEnvironment()mailServer := env.MailServermailUsername := env.MailUsernameSMTP := fmt.Sprintf("%s:%s", mailServer, env.MailPort)auth := LoginAuth(mailUsername, env.MailPassword)tlsconfig := &tls.Config{    ServerName: mailServer,}c, err := smtp.Dial(SMTP)if err != nil {    zap.S().Error(err)    return false}c.StartTLS(tlsconfig)if err = c.Auth(auth); err != nil {    zap.S().Error(err)    return false}if err = c.Mail(mailUsername); err != nil {    zap.S().Error(err)    return false}if err = c.Rcpt(to); err != nil {    zap.S().Error(err)    return false}w, err := c.Data()if err != nil {    zap.S().Error(err)    return false}_, err = w.Write([]byte(body))if err != nil {    zap.S().Error(err)    return false}err = w.Close()if err != nil {    zap.S().Error(err)    return false}c.Quit()return true}身份驗證功能; import (    "errors"    "net/smtp")type loginAuth struct {    username, password string}func LoginAuth(username, password string) smtp.Auth {    return &loginAuth{username, password}}func (a *loginAuth) Start(server *smtp.ServerInfo) (string, []byte, error) {    return "LOGIN", []byte(a.username), nil}func (a *loginAuth) Next(fromServer []byte, more bool) ([]byte, error) {    if more {        switch string(fromServer) {        case "Username:":            return []byte(a.username), nil        case "Password:":            return []byte(a.password), nil        default:            return nil, errors.New("unknown from server")        }    }    return nil, nil}感謝您的幫助
查看完整描述

2 回答

?
呼如林

TA貢獻1798條經驗 獲得超3個贊

您收到的錯誤肯定是從smtp服務器返回的。smtp 協議支持多種身份驗證機制。如果您不確定服務器支持哪些,可以使用以下命令手動調試它。發送到服務器后,它將宣布支持的身份驗證機制。然后,您可以嘗試手動登錄并正確實施。
請注意,某些方法需要對登錄名和密碼進行編碼(base64、md5 等)。openssl s_client -crlf -ign_eof -connect <smtp_host>:<TLS_port>EHLOStart()Next()

查看完整回答
反對 回復 2022-09-05
?
RISEBY

TA貢獻1856條經驗 獲得超5個贊

命令“AUTH LOGIN”不需要用戶名參數。


請嘗試以下操作,您的身份驗證可能會起作用(如果支持)


func (a *loginAuth) Start(server *smtp.ServerInfo) (string, []byte, error) {

    return "LOGIN", nil, nil

}


查看完整回答
反對 回復 2022-09-05
  • 2 回答
  • 0 關注
  • 564 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號