email.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package common
  2. import (
  3. "crypto/tls"
  4. "encoding/base64"
  5. "fmt"
  6. "net/smtp"
  7. "strings"
  8. )
  9. func SendEmail(subject string, receiver string, content string) error {
  10. encodedSubject := fmt.Sprintf("=?UTF-8?B?%s?=", base64.StdEncoding.EncodeToString([]byte(subject)))
  11. mail := []byte(fmt.Sprintf("To: %s\r\n"+
  12. "From: %s<%s>\r\n"+
  13. "Subject: %s\r\n"+
  14. "Content-Type: text/html; charset=UTF-8\r\n\r\n%s\r\n",
  15. receiver, SystemName, SMTPAccount, encodedSubject, content))
  16. auth := smtp.PlainAuth("", SMTPAccount, SMTPToken, SMTPServer)
  17. addr := fmt.Sprintf("%s:%d", SMTPServer, SMTPPort)
  18. to := strings.Split(receiver, ";")
  19. var err error
  20. if SMTPPort == 465 {
  21. tlsConfig := &tls.Config{
  22. InsecureSkipVerify: true,
  23. ServerName: SMTPServer,
  24. }
  25. conn, err := tls.Dial("tcp", fmt.Sprintf("%s:%d", SMTPServer, SMTPPort), tlsConfig)
  26. if err != nil {
  27. return err
  28. }
  29. client, err := smtp.NewClient(conn, SMTPServer)
  30. if err != nil {
  31. return err
  32. }
  33. defer client.Close()
  34. if err = client.Auth(auth); err != nil {
  35. return err
  36. }
  37. if err = client.Mail(SMTPAccount); err != nil {
  38. return err
  39. }
  40. receiverEmails := strings.Split(receiver, ";")
  41. for _, receiver := range receiverEmails {
  42. if err = client.Rcpt(receiver); err != nil {
  43. return err
  44. }
  45. }
  46. w, err := client.Data()
  47. if err != nil {
  48. return err
  49. }
  50. _, err = w.Write(mail)
  51. if err != nil {
  52. return err
  53. }
  54. err = w.Close()
  55. if err != nil {
  56. return err
  57. }
  58. } else {
  59. err = smtp.SendMail(addr, auth, SMTPAccount, to, mail)
  60. }
  61. return err
  62. }