Wprowadzenie do Gomail

Gomail to prosty i wydajny pakiet do wysyłania e-maili w języku Golang. Został gruntownie przetestowany i udokumentowany.

Gomail może wysyłać e-maile tylko za pomocą serwerów SMTP. Jednak interfejs API jest elastyczny i można łatwo zaimplementować metody takie jak korzystanie z lokalnego Postfixa, interfejsów API, itp. do wysyłania e-maili.

Wykorzystuje gopkg.in do kontroli wersji, dzięki czemu w każdej wersji nie będą występować niekompatybilne zmiany.

Wymaga użycia Go 1.2 lub późniejszej wersji. W Go 1.5 zewnętrzne zależności nie będą używane.

Funkcje Gomail

Gomail obsługuje następujące funkcje:

  • Załączniki
  • Wbudowane obrazy
  • Szablony HTML i tekstowe
  • Automatyczne kodowanie specjalnych znaków
  • SSL i TLS
  • Wysyłanie wielu e-maili za pomocą tego samego połączenia SMTP

Instalacja

go get gopkg.in/gomail.v2

Przykład

m := gomail.NewMessage()
m.SetHeader("From", "[email protected]")
m.SetHeader("To", "[email protected]", "[email protected]")
m.SetAddressHeader("Cc", "[email protected]", "Dan")
m.SetHeader("Subject", "Hello!")
m.SetBody("text/html", "Hello <b>Bob</b> and <i>Cora</i>!")
m.Attach("/home/Alex/lolcat.jpg")

d := gomail.NewDialer("smtp.example.com", 587, "user", "123456")

// Wyślij e-mail do Boba, Cora i Dana.
if err := d.DialAndSend(m); err != nil {
    panic(err)
}

Przykład (Demon)

Demon nasłuchujący kanał i wysyłający wszystkie otrzymane wiadomości.

ch := make(chan *gomail.Message)

go func() {
    d := gomail.NewDialer("smtp.example.com", 587, "user", "123456")

    var s gomail.SendCloser
    var err error
    open := false
    for {
        select {
        case m, ok := <-ch:
            if !ok {
                return
            }
            if !open {
                if s, err = d.Dial(); err != nil {
                    panic(err)
                }
                open = true
            }
            if err := gomail.Send(s, m); err != nil {
                log.Print(err)
            }
        // Zamknij połączenie do serwera SMTP, jeśli w ciągu ostatnich 30 sekund nie został wysłany żaden e-mail.
        case <-time.After(30 * time.Second):
            if open {
                if err := s.Close(); err != nil {
                    panic(err)
                }
                open = false
            }
        }
    }
}()

// Wyślij e-maile, korzystając z tego kanału w swoim programie.

// Zamknij kanał, aby zatrzymać demona e-mail.
close(ch)

Przykład (Subskrypcja e-maili)

Efektywne wysyłanie spersonalizowanych subskrypcji e-maili do grupy odbiorców.

// Lista odbiorców.
var list []struct {
    Name    string
    Address string
}

d := gomail.NewDialer("smtp.example.com", 587, "user", "123456")
s, err := d.Dial()
if err != nil {
    panic(err)
}

m := gomail.NewMessage()
for _, r := range list {
    m.SetHeader("From", "[email protected]")
    m.SetAddressHeader("To", r.Address, r.Name)
    m.SetHeader("Subject", "Newsletter #1")
    m.SetBody("text/html", fmt.Sprintf("Hello %s!", r.Name))

    if err := gomail.Send(s, m); err != nil {
        log.Printf("Nie można wysłać e-maila do %q: %v", r.Address, err)
    }
    m.Reset()
}

Przykład (Brak uwierzytelnienia)

Wysyłanie e-maili za pomocą lokalnego serwera SMTP.

m := gomail.NewMessage()
m.SetHeader("From", "[email protected]")
m.SetHeader("To", "[email protected]")
m.SetHeader("Subject", "Hello!")
m.SetBody("text/plain", "Hello!")

d := gomail.Dialer{Host: "localhost", Port: 587}
if err := d.DialAndSend(m); err != nil {
    panic(err)
}

Przykład (bez SMTP)

Wysyłanie e-maili za pomocą interfejsu API lub postfix.

m := gomail.NewMessage()
m.SetHeader("From", "[email protected]")
m.SetHeader("To", "[email protected]")
m.SetHeader("Subject", "Cześć!")
m.SetBody("text/plain", "Cześć!")

s := gomail.SendFunc(func(from string, to []string, msg io.WriterTo) error {
    // Własna implementacja funkcji wysyłania e-maili poprzez wywołanie interfejsu API lub uruchomienie postfix, itp.
    fmt.Println("Od:", from)
    fmt.Println("Do:", to)
    return nil
})

if err := gomail.Send(s, m); err != nil {
    panic(err)
}

FAQ

x509: certyfikat podpisany przez nieznaną jednostkę certyfikującą

Jeśli napotkasz ten błąd, oznacza to, że klient korzystający z Gomail uważa, że certyfikat używany przez serwer SMTP jest nieważny. Jako obejście możesz zignorować walidację łańcucha certyfikatów serwera i nazwy hosta, korzystając z SetTLSConfig:

package main

import (
	"crypto/tls"
	
	"gopkg.in/gomail.v2"
)

func main() {
	d := gomail.NewDialer("smtp.example.com", 587, "user", "123456")
	d.TLSConfig = &tls.Config{InsecureSkipVerify: true}

    // Użyj d do wysyłania e-maili.
}

Jednakże zwróć uwagę, że jest to niebezpieczne i nie powinno być używane w środowisku produkcyjnym.