E-Mails mit der Mail API senden und empfangen

In dieser Anleitung wird beschrieben, wie Sie mit der Mail API E-Mails senden und empfangen.

Vorbereitung

Sie müssen Ihre Absenderadressen als autorisierte Absender registrieren. Weitere Informationen finden Sie unter Wer kann E-Mails senden?.

E-Mails senden

So senden Sie E-Mails aus einer Anwendung:

  1. Legen Sie mit dem Typ mail.Message den Absender, den Empfänger, den Betreff und den Text der Nachricht fest.

  2. Senden Sie die E-Mail mit der Funktion mail.Send.

Im folgenden Beispiel wird eine E-Mail-Nachricht an einen Nutzer gesendet, um die Erstellung eines neuen Kontos mit der Anwendung zu bestätigen:

import (
	"bytes"
	"fmt"
	"net/http"

	"google.golang.org/appengine"
	"google.golang.org/appengine/log"
	"google.golang.org/appengine/mail"
)

func confirm(w http.ResponseWriter, r *http.Request) {
	ctx := appengine.NewContext(r)
	addr := r.FormValue("email")
	url := createConfirmationURL(r)
	msg := &mail.Message{
		Sender:  "Example.com Support <support@example.com>",
		To:      []string{addr},
		Subject: "Confirm your registration",
		Body:    fmt.Sprintf(confirmMessage, url),
	}
	if err := mail.Send(ctx, msg); err != nil {
		log.Errorf(ctx, "Couldn't send email: %v", err)
	}
}

const confirmMessage = `
Thank you for creating an account!
Please confirm your email address by clicking on the link below:

%s
`

E-Mails empfangen

Sie können Ihre Anwendung dafür einrichten, E-Mails über Adressen mit dem folgenden Format zu empfangen:

anything@appid.appspotmail.com

So empfangen Sie E-Mails:

  1. Aktivieren Sie eingehende E-Mails in der Datei app.yaml Ihrer Anwendung.

    inbound_services:
    - mail
  2. Richten Sie einen Handler zur Verarbeitung eingehender E-Mails ein, die der Anwendung als MIME-Daten in einer HTTP-POST-Anfrage bereitgestellt werden.

    1. Registrieren Sie in Ihrer App einen Handler für den /_ah/mail/ Pfad :

      func init() {
      	http.HandleFunc("/_ah/mail/", incomingMail)
      }
      
    2. Lesen Sie im Handler die Daten der E-Mail aus *http.Request:

      func incomingMail(w http.ResponseWriter, r *http.Request) {
      	ctx := appengine.NewContext(r)
      	defer r.Body.Close()
      	var b bytes.Buffer
      	if _, err := b.ReadFrom(r.Body); err != nil {
      		log.Errorf(ctx, "Error reading body: %v", err)
      		return
      	}
      	log.Infof(ctx, "Received mail: %v", b)
      }
      

    Sie können das net/mail-Paket in der Standardbibliothek zum Parsen von E-Mail-Nachrichten verwenden.