| Seleziona la piattaforma: | iOS+ Android Web Flutter Unity C++ |
Questa guida descrive come iniziare a utilizzare Firebase Cloud Messaging nelle app client web per poter inviare messaggi in modo affidabile.
L'API FCM JavaScript consente di ricevere messaggi di notifica nelle app web in esecuzione nei browser che supportano l' API Push. Sono incluse le versioni del browser elencate in questa matrice di supporto e le estensioni di Chrome che utilizzano l'API Push.
L'SDK FCM è supportato solo nelle pagine pubblicate tramite HTTPS. Questo perché utilizza i service worker, che sono disponibili solo sui siti HTTPS. Se hai bisogno di un provider, Firebase App Hosting è consigliato e offre un piano senza costi per l'hosting HTTPS sul tuo dominio.
Per iniziare a utilizzare l'API JavaScript FCM, devi aggiungere Firebase alla tua app web e aggiungere la logica per accedere agli ID di installazione di Firebase, che ti consentono di designare il destinatario delle notifiche.
Aggiungere e inizializzare l'SDK FCM
Se non l'hai già fatto, installa l'SDK Firebase JS e inizializza Firebase.
Aggiungi l'SDK Firebase Cloud Messaging JS e inizializza Firebase Cloud Messaging:
Web
import { initializeApp } from "firebase/app"; import { getMessaging } from "firebase/messaging"; // TODO: Replace the following with your app's Firebase project configuration // See: https://firebase.google.com/docs/web/learn-more#config-object const firebaseConfig = { // ... }; // Initialize Firebase const app = initializeApp(firebaseConfig); // Initialize Firebase Cloud Messaging and get a reference to the service const messaging = getMessaging(app);
Web
import firebase from "firebase/compat/app"; import "firebase/compat/messaging"; // TODO: Replace the following with your app's Firebase project configuration // See: https://firebase.google.com/docs/web/learn-more#config-object const firebaseConfig = { // ... }; // Initialize Firebase firebase.initializeApp(firebaseConfig); // Initialize Firebase Cloud Messaging and get a reference to the service const messaging = firebase.messaging();
Se utilizzi FCM per il web e vuoi eseguire l'upgrade all'SDK 6.7.0 o versioni successive, devi attivare l' API di registrazione FCM per il tuo progetto nella Google Cloud console. Quando attivi l'API, assicurati di aver eseguito l'accesso alla Google Cloud console con lo stesso Account Google che utilizzi per Firebase e di selezionare il progetto corretto. Per i nuovi progetti che aggiungono l' FCM SDK, questa API è attivata per impostazione predefinita.
Configurare le credenziali web con FCM
L'interfaccia web di FCM utilizza credenziali web chiamate Voluntary Application Server Identification o chiavi VAPID per autorizzare le richieste di invio ai servizi web push supportati. Per abbonare la tua app alle notifiche push, devi associare una coppia di chiavi al tuo progetto Firebase. Puoi generare una nuova coppia di chiavi o importare quella esistente tramite la Firebase console.
Generare una nuova coppia di chiavi
Nella Firebase console, vai a
Impostazioni > Generali. Quindi, fai clic sulla scheda Cloud MessagingVai alla sezione Configurazione web.
Nella scheda Certificati web push, fai clic su Genera coppia di chiavi.
La console mostra un avviso che indica che la coppia di chiavi è stata generata, la stringa della chiave pubblica e la data di aggiunta.
Importare una coppia di chiavi esistente
Se hai una coppia di chiavi esistente che utilizzi già con la tua app web, puoi importarla in FCM in modo da poter raggiungere le istanze dell'app web esistenti tramite le API FCM. Per importare le chiavi, devi disporre dell'accesso a livello di proprietario al progetto Firebase. Importa la chiave pubblica e privata esistente in formato con codifica Base64 URL safe:
Nella Firebase console, vai a
Impostazioni > Generali. Quindi, fai clic sulla scheda Cloud MessagingVai alla sezione Configurazione web.
Nella scheda Certificati web push, individua e seleziona il testo del link: importa una coppia di chiavi esistente.
Nella finestra di dialogo Importa una coppia di chiavi, fornisci le chiavi pubblica e privata nei campi corrispondenti e fai clic su Importa.
La console mostra la stringa della chiave pubblica e la data di aggiunta.
Per istruzioni su come aggiungere la chiave all'app, consulta Configurare le credenziali web nell'app. Per maggiori informazioni sul formato delle chiavi e su come generarle, consulta Chiavi del server applicazioni.
Configurare le credenziali web nell'app
Il metodo register(): Promise<void>
consente a FCM di utilizzare la credenziale della chiave VAPID quando invia richieste di messaggi a diversi servizi push. Utilizzando la chiave generata o importata
in base alle istruzioni riportate in
Configurare le credenziali web con FCM,
aggiungila al codice dopo aver recuperato l'oggetto di messaggistica:
import { getMessaging, register } from "firebase/messaging";
const messaging = getMessaging();
// Add the public key generated from the Firebase console here.
register(messaging, {vapidKey: "BKagOny0KF_2pCJQ3m....moL0ewzQ8rZu"});
Richiedere l'autorizzazione alle notifiche e configurare il service worker
Quando devi scegliere come target un'istanza dell'app con FCM, richiedi prima
le autorizzazioni alle notifiche all'utente con
Notification.requestPermission(). Se chiamato come mostrato, questo
metodo restituisce lo stato dell'autorizzazione se concessa:
function requestPermission() {
console.log('Requesting permission...');
Notification.requestPermission().then((permission) => {
if (permission === 'granted') {
console.log('Notification permission granted.');
}
});
}FCM richiede un file firebase-messaging-sw.js. A meno che tu non abbia già un file firebase-messaging-sw.js, creane uno vuoto con questo nome e inseriscilo nella root del tuo dominio prima della registrazione. Puoi aggiungere contenuti significativi al file in un secondo momento durante la procedura di configurazione del client.
Accedere all'ID di installazione di Firebase
Per registrare l'istanza dell'app e recuperare l'ID di installazione di Firebase (FID) per il targeting dei messaggi:
import { getMessaging, onRegistered, register } from "firebase/messaging"; const messaging = getMessaging(); // 1. Implement callback to receive the Firebase installation ID upon registration. // This is triggered every time a manual register() finishes, a FID change // is detected, or a pushsubscriptionchange event is fired. onRegistered(messaging, (installationId) => { console.log('Registered installation ID:', installationId); // Send the Firebase Installation ID to your app server and update the UI if needed. sendRegistrationToServer(installationId); }); // 2. You can also manually trigger registration (recommended on app startup) register(messaging, { vapidKey: '<YOUR_PUBLIC_VAPID_KEY_HERE>' }).then(() => { // Success! The Firebase Installation ID can be used to target messages to this app // instance and will be delivered asynchronously to your onRegistered() callback. }).catch((err) => { console.error('An error occurred while registering', err); });
Il
onRegistered
callback viene attivato in tre scenari:
-
Ogni volta che una chiamata manuale
register()viene completata. - Viene rilevata una modifica dell'ID di installazione di Firebase.
-
Viene attivato un
pushsubscriptionchangeevento.
Dopo aver ottenuto l'ID di installazione di Firebase, invialo al server dell'app e archivialo utilizzando il metodo che preferisci.
Accedere al token di registrazione (obsoleto)
Per recuperare il token corrente:
Web
import { getMessaging, getToken } from "firebase/messaging"; // Get registration token. Initially this makes a network call, once retrieved // subsequent calls to getToken will return from cache. const messaging = getMessaging(); getToken(messaging, { vapidKey: '<YOUR_PUBLIC_VAPID_KEY_HERE>' }).then((currentToken) => { if (currentToken) { // Send the token to your server and update the UI if necessary // ... } else { // Show permission request UI console.log('No registration token available. Request permission to generate one.'); // ... } }).catch((err) => { console.log('An error occurred while retrieving token. ', err); // ... });
Web
// Get registration token. Initially this makes a network call, once retrieved // subsequent calls to getToken will return from cache. messaging.getToken({ vapidKey: '<YOUR_PUBLIC_VAPID_KEY_HERE>' }).then((currentToken) => { if (currentToken) { // Send the token to your server and update the UI if necessary // ... } else { // Show permission request UI console.log('No registration token available. Request permission to generate one.'); // ... } }).catch((err) => { console.log('An error occurred while retrieving token. ', err); // ... });
Dopo aver ottenuto il token, invialo al server dell'app e archivialo utilizzando il metodo che preferisci.
Inviare un messaggio di notifica di prova
Installa ed esegui l'app sul dispositivo di destinazione. Sui dispositivi Apple, dovrai accettare la richiesta di autorizzazione a ricevere notifiche remote.
Verifica che l'app sia in background sul dispositivo.
Nella console Firebase, vai a DevOps e coinvolgimento > Messaggistica
Crea una campagna.
Se è il tuo primo messaggio:
Seleziona Crea la tua prima campagna.
Seleziona Messaggi di notifica Firebase e poi Crea.
Se hai già creato campagne:
Nella scheda Campagne, seleziona Nuova campagna.
Fai clic su Notifiche.
Inserisci il testo del messaggio.
Seleziona Invia messaggio di prova nel riquadro a destra.
Nel campo Aggiungi un token di registrazione, inserisci il tuo token di registrazione.FCM
Seleziona Testa.
Dopo aver selezionato Testa, il dispositivo client di destinazione, con l'app in background, dovrebbe ricevere la notifica.
Passaggi successivi
Dopo aver completato i passaggi di configurazione, ecco alcune opzioni per procedere con FCM per il web (JavaScript):
- Inviare messaggi ai dispositivi
- Ricevere messaggi in un client JavaScript
- Inviare messaggi agli argomenti