golang 通过loginauth方式发送加密邮件

公司邮箱走的是873端口的加密协议,参考了一下网上的资料自己整合了一下

package main


import (
"crypto/tls"
"fmt"
"log"
"net"
"net/smtp"
)


// login auth认证方式
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{}, nil
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
}
}
return nil, nil
}


// 发送邮件到具体邮箱
func Send(body, toEmail string) {
host := "xxxx"
port := xxxx
email := "xxxxx"
password := "xxxxx"


header := make(map[string]string)
header["From"] = "test" + "<" + email + ">"
header["To"] = toEmail
header["Subject"] = "xxxx"
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


auth := LoginAuth("xxxxx", password)


err := SendMailUsingTLS(
fmt.Sprintf("%s:%d", host, port),
auth,
email,
[]string{toEmail},
[]byte(message),
)


if err != nil {
panic(err)
}
}


//return a smtp client
func Dial(addr string) (*smtp.Client, error) {
conn, err := net.Dial("tcp", addr)
if err != nil {
log.Println("Dialing Error:", err)
return nil, err
}
//分解主机端口字符串
host, _, _ := net.SplitHostPort(addr)
return smtp.NewClient(conn, host)
}


//参考net/smtp的func SendMail()
//使用net.Dial连接tls(ssl)端口时,smtp.NewClient()会卡住且不提示err
//len(to)>1时,to[1]开始提示是密送
func SendMailUsingTLS(addr string, auth smtp.Auth, from string,
to []string, msg []byte) (err error) {


//create smtp client
c, err := Dial(addr)
if err != nil {
log.Println("Create smpt client error:", err)
return err
}
defer c.Close()
config := &tls.Config{
ServerName:   "xxxxx",
CipherSuites: []uint16{tls.TLS_RSA_WITH_RC4_128_SHA},
}
c.StartTLS(config)
if auth != nil {
if ok, _ := c.Extension("AUTH"); ok {
if err = c.Auth(auth); err != nil {
log.Println("Error during AUTH", err)
return err
}
}
}


if err = c.Mail(from); err != nil {
log.Println("1", err)
return err
}


for _, addr := range to {
if err = c.Rcpt(addr); err != nil {
log.Println("2", err)
return err
}
}


w, err := c.Data()
if err != nil {
log.Println("3", err)
return err
}


_, err = w.Write(msg)
if err != nil {
log.Println("4", err)
return err
}


err = w.Close()
if err != nil {
log.Println("5", err)
return err
}


return c.Quit()
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值