package main
import (
"crypto/tls"
"fmt"
"net/smtp"
)
// 邮件发送函数
func SendMail(user, password, host, to, subject, body string, port int, isSSL bool) error {
// 设置邮件头部
header := make(map[string]string)
header["From"] = user
header["To"] = to
header["Subject"] = subject
header["Content-Type"] = "text/html; charset=UTF-8"
// 组装邮件正文
message := ""
for k, v := range header {
message += fmt.Sprintf("%s: %s\r\n", k, v)
}
message += "\r\n" + body
// 建立SMTP客户端
hostAddr := fmt.Sprintf("%s:%d", host, port)
var auth smtp.Auth
if isSSL {
auth = smtp.CRAMMD5Auth(user, password)
} else {
auth = smtp.PlainAuth("", user, password, host)
}
// 发送邮件
if isSSL {
conn, err := tls.Dial("tcp", hostAddr, &tls.Config{})
if err != nil {
return err
}
defer conn.Close()
client, err := smtp.NewClient(conn, host)
if err != nil {
return err
}
if err := client.Auth(auth); err != nil {
return err
}
if err := client.Mail(user); err != nil {
return err
}
if err := client.Rcpt(to); err != nil {
return err
}
w, err := client.Data()
if err != nil {
return err
}
_, err = w.Write([]byte(message))
if err != nil {
return err
}
err = w.Close()
if err != nil {
return err
}
return client.Quit()
} else {
return smtp.SendMail(hostAddr, auth, user, []string{to}, []byte(message))
}
}
func main() {
// 测试邮件发送
user := "your_email@163.com" // 发送方邮箱
password := "your_email_password" // 发送方邮箱密码
host := "smtp.163.com" // 邮件服务器地址
to := "recipient_email@gmail.com" // 接收方邮箱
subject := "Test Email" // 邮件主题
body := "This is a test email." // 邮件正文
port := 25 // 端口
isSSL := false // 是否使用SSL
err := SendMail(user, password, host, to, subject, body, port, isSSL)
if err != nil {
fmt.Println("发送失败:", err)
return
}
fmt.Println("发送成功")
}
这段代码提供了一个简化版本的邮件发送功能,可以用来发送邮件。代码中的SendMail
函数负责设置邮件头部、组装邮件正文、建立SMTP连接、身份验证以及发送邮件。在main
函数中,我们可以通过修改相关变量来测试不同的邮件发送场景。注意,实际使用时需要替换user
、password
、to
等变量的值为你的实际邮箱信息。