email.go 1.6 KB

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