Reach

Grow

Manage

Automate

Reach

Grow

Manage

Automate

Una guida all'uso di SparkPost con Node.js

Email

1 min read

Una guida all'uso di SparkPost con Node.js

Email

1 min read

Una guida all'uso di SparkPost con Node.js

Come Developer Advocate per SparkPost, scrivo molte applicazioni di esempio. Il mio background è per lo più nello sviluppo front-end, quindi il mio linguaggio più forte è JavaScript. Grazie a Node.js, sono anche un discreto sviluppatore backend. Questo significa che ora sono uno sviluppatore full stack?

Introduzione a Node.js

Come Developer Advocate per SparkPost, scrivo molte applicazioni di esempio. Il mio background è principalmente nello sviluppo front-end, quindi il mio linguaggio più forte è JavaScript. Grazie a Node.js, sono anche un discreto sviluppatore backend. Questo significa che ora sono uno sviluppatore full stack? Ad ogni modo, era importante per me che avessimo una fantastica libreria client di SparkPost per Node.js. Quindi, mi sono immerso direttamente e sono diventato un collaboratore (anche prima di essere assunto).

Permettimi di aiutarti a iniziare a inviare email con SparkPost sul tuo progetto Node.js.

Installing & Setup

Presumo che tu abbia installato Node.js. Poiché seguiamo il programma di supporto a lungo termine (LTS) di Node.js, dovrai utilizzare la versione 4 o superiore. Puoi vedere quale versione stai utilizzando usando il comando `node –version` nella tua finestra del terminale.

Creiamo un nuovo progetto npm. Se ne hai già uno, puoi saltare questa parte.

> mkdir sparkpost-test > cd sparkpost-test > npm init --yes

Questo creerà un nuovo progetto e accetterà tutti i valori predefiniti. Puoi anche eseguire `npm init` e rispondere a tutte le domande.

Ora possiamo installare node-sparkpost:

> npm install sparkpost --save

Una volta installato, puoi importare e creare un'istanza della classe SparkPost:

const SparkPost = require('sparkpost') const client = new SparkPost('YOUR API KEY')

È buona pratica evitare di inserire la tua chiave API nel codice. Consigliamo vivamente di memorizzarla al di fuori del codice, quindi abbiamo configurato la libreria client per rilevare la variabile di ambiente SPARKPOST_API_KEY.

Presumo che tu abbia installato Node.js. Poiché seguiamo il programma di supporto a lungo termine (LTS) di Node.js, dovrai utilizzare la versione 4 o superiore. Puoi vedere quale versione stai utilizzando usando il comando `node –version` nella tua finestra del terminale.

Creiamo un nuovo progetto npm. Se ne hai già uno, puoi saltare questa parte.

> mkdir sparkpost-test > cd sparkpost-test > npm init --yes

Questo creerà un nuovo progetto e accetterà tutti i valori predefiniti. Puoi anche eseguire `npm init` e rispondere a tutte le domande.

Ora possiamo installare node-sparkpost:

> npm install sparkpost --save

Una volta installato, puoi importare e creare un'istanza della classe SparkPost:

const SparkPost = require('sparkpost') const client = new SparkPost('YOUR API KEY')

È buona pratica evitare di inserire la tua chiave API nel codice. Consigliamo vivamente di memorizzarla al di fuori del codice, quindi abbiamo configurato la libreria client per rilevare la variabile di ambiente SPARKPOST_API_KEY.

Presumo che tu abbia installato Node.js. Poiché seguiamo il programma di supporto a lungo termine (LTS) di Node.js, dovrai utilizzare la versione 4 o superiore. Puoi vedere quale versione stai utilizzando usando il comando `node –version` nella tua finestra del terminale.

Creiamo un nuovo progetto npm. Se ne hai già uno, puoi saltare questa parte.

> mkdir sparkpost-test > cd sparkpost-test > npm init --yes

Questo creerà un nuovo progetto e accetterà tutti i valori predefiniti. Puoi anche eseguire `npm init` e rispondere a tutte le domande.

Ora possiamo installare node-sparkpost:

> npm install sparkpost --save

Una volta installato, puoi importare e creare un'istanza della classe SparkPost:

const SparkPost = require('sparkpost') const client = new SparkPost('YOUR API KEY')

È buona pratica evitare di inserire la tua chiave API nel codice. Consigliamo vivamente di memorizzarla al di fuori del codice, quindi abbiamo configurato la libreria client per rilevare la variabile di ambiente SPARKPOST_API_KEY.

Invio Email

Ora che hai un'istanza di SparkPost, sei pronto per inviare. Ci sono parecchie opzioni disponibili per l'invio, ma iniziamo con un semplice esempio. Ecco come inviare un'email a un singolo destinatario, specificando il contenuto inline:

client.transmissions.send({ content: { from: 'test@your-sending-domain.com', subject: 'Hello from node-sparkpost', html: '<p>Hello world</p>' }, recipients: [ {address: 'someone@somedomain.com'} ] }) .then(data => { console.log('Woohoo! Hai appena inviato il tuo primo invio!') console.log(data) }) .catch(err => { console.log('Whoops! Qualcosa è andato storto') console.log(err) })

Nota: Questo esempio utilizza Promises, ma non preoccuparti. Supportiamo anche le funzioni di callback.

Ci sono più opzioni disponibili con le trasmissioni, tra cui specificare modelli memorizzati o elenchi di destinatari, cc e bcc, aggiungere allegati, specificare una campagna, utilizzare dati di sostituzione e molto altro. Dai un'occhiata agli esempi, alla documentazione per la risorsa Transmissions e alla documentazione API delle Transmissions per maggiori informazioni.

Bonus: Inviare Email con Nodemailer

Nodemailer è una libreria popolare per Node.js che rende l'invio di email “facile come una torta.” Per coloro che scelgono di utilizzare questa libreria, abbiamo creato un SparkPost transport per Nodemailer. Dovrai installare i pacchetti nodemailer e nodemailer-sparkpost-transport nel tuo progetto.

> npm install nodemailer nodemailer-sparkpost-transport --save

Ora puoi creare un'istanza di trasporto nodemailer:

const nodemailer = require('nodemailer') const sparkPostTransport = require('nodemailer-sparkpost-transport') const transporter = nodemailer.createTransport(sparkPostTransport({ 'sparkPostApiKey': process.env.SPARKPOST_API_KEY }))

 

Nota come sto leggendo la chiave API da una variabile d'ambiente. È ancora una buona pratica non inserirla mai direttamente nel tuo codice.

Ci sono diverse opzioni che possono essere passate nel SparkPost transport, come l'id della campagna e se il messaggio è transazionale o meno. Dai un'occhiata al README.md per tutte le opzioni.

Ecco come invieresti lo stesso messaggio sopra usando Nodemailer:

transporter.sendMail({ from: 'test@your-sending-domain.com', to: 'someone@somedomain.com', subject: 'Hello from nodemailer-sparkpost-transport', html: '<p>Hello world</p>' }, (err, info) => { if (err) { console.error(err); } else { console.log(info); } })

Double Bonus: Inviare Email con notif.me

Tutti sappiamo che l'email è il re della comunicazione, ma a volte vuoi essere in grado di raggiungere le persone tramite più canali. notif.me è una libreria Node.js per l'invio di tutti i tipi di messaggi transazionali. Che tu voglia inviare un'email, sms, push o webpushes, puoi farlo facilmente. Ha anche strategie di fallback e round robin integrate per più provider. Abbiamo recentemente lavorato con i creatori per costruire un provider SparkPost. Avrai bisogno di installare il pacchetto `notifme-sdk` nel tuo progetto.

> npm install notifme-sdk --save

Ora puoi creare un'istanza di notifme con il provider SparkPost:

const NotifmeSdk = require('notifme-sdk').default const notifmeSdk = new NotifmeSdk({ channels: { email: { providers: [{ type: 'sparkpost', apiKey: process.env.SPARKPOST_API_KEY, }] } } })

Di nuovo, stiamo prendendo la chiave API da una variabile di ambiente. L'abbiamo detto tre volte — è davvero importante. 🙂

Ora ripetiamo lo stesso esempio, stavolta usando notif.me:

notifmeSdk.send({ email: { from: 'test@your-sending-domain.com', to: 'someone@somedomain.com', subject: 'Hello from the SparkPost notif.me provider', html: '<p>Hello world</p>' } }).then(console.log)

È davvero facile da usare e consiglio di dare un'occhiata alle altre funzionalità.

Non c'è modo sbagliato di usare Node

Quando si tratta di inviare email utilizzando Node.js, hai molte opzioni. Abbiamo lavorato duramente per renderlo il più indolore possibile.

Connettiamoci con un esperto di Bird.
Scopri tutta la potenza del Bird in 30 minuti.

Inviando, accetti che Bird possa contattarti riguardo ai nostri prodotti e servizi.

Puoi annullare l'iscrizione in qualsiasi momento. Consulta la Informativa sulla Privacy di Bird per i dettagli sul trattamento dei dati.

Azienda

Newsletter

Rimani aggiornato con Bird attraverso aggiornamenti settimanali nella tua inbox.

Inviando, accetti che Bird possa contattarti riguardo ai nostri prodotti e servizi.

Puoi annullare l'iscrizione in qualsiasi momento. Consulta la Informativa sulla Privacy di Bird per i dettagli sul trattamento dei dati.

Connettiamoci con un esperto di Bird.
Scopri tutta la potenza del Bird in 30 minuti.

Inviando, accetti che Bird possa contattarti riguardo ai nostri prodotti e servizi.

Puoi annullare l'iscrizione in qualsiasi momento. Consulta la Informativa sulla Privacy di Bird per i dettagli sul trattamento dei dati.

Azienda

Newsletter

Rimani aggiornato con Bird attraverso aggiornamenti settimanali nella tua inbox.

Inviando, accetti che Bird possa contattarti riguardo ai nostri prodotti e servizi.

Puoi annullare l'iscrizione in qualsiasi momento. Consulta la Informativa sulla Privacy di Bird per i dettagli sul trattamento dei dati.

Connettiamoci con un esperto di Bird.
Scopri tutta la potenza del Bird in 30 minuti.

Inviando, accetti che Bird possa contattarti riguardo ai nostri prodotti e servizi.

Puoi annullare l'iscrizione in qualsiasi momento. Consulta la Informativa sulla Privacy di Bird per i dettagli sul trattamento dei dati.

R

Raggiungi

G

Grow

M

Manage

A

Automate

Azienda

Newsletter

Rimani aggiornato con Bird attraverso aggiornamenti settimanali nella tua inbox.

Inviando, accetti che Bird possa contattarti riguardo ai nostri prodotti e servizi.

Puoi annullare l'iscrizione in qualsiasi momento. Consulta la Informativa sulla Privacy di Bird per i dettagli sul trattamento dei dati.