Invio e ricezione della posta con l'API Mail

Questa guida descrive come utilizzare l'API Mail per inviare e ricevere posta.

Prima di iniziare

Devi registrare i tuoi indirizzi email come mittenti autorizzati. Per scoprire di più, consulta l'articolo su chi può inviare email.

Invio di messaggi

Per inviare posta dalla tua applicazione:

  1. Utilizza il tipo mail.Message per impostare il mittente, il destinatario, l'oggetto e il corpo del messaggio.

  2. Invia l'email con la funzione mail.Send.

L'esempio seguente invia un messaggio e-mail all'utente per confermare che ha creato un nuovo account con l'applicazione:

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
`

Ricezione di messaggi

Puoi configurare la tua app in modo da ricevere le email in arrivo a indirizzi nel seguente formato:

anything@appid.appspotmail.com

Per ricevere email:

  1. Attiva la posta in arrivo nel file app.yaml della tua app:

    inbound_services:
    - mail
  2. Imposta un gestore per l'elaborazione delle email in arrivo fornite alla tua app come dati MIME in una richiesta POST HTTP.

    1. Nell'app, registra un gestore nel percorso /_ah/mail/:

      func init() {
      	http.HandleFunc("/_ah/mail/", incomingMail)
      }
      
    2. Nel gestore, leggi i dati dell'email dal *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)
      }
      

    Puoi utilizzare il pacchetto net/mail nella libreria standard per analizzare i messaggi di posta.