FCM JavaScript API'si, Push API'yi destekleyen tarayıcılarda çalışan web uygulamalarında bildirim mesajları almanıza olanak tanır. Bu kapsamda, bu destek matrisinde listelenen tarayıcı sürümleri ve Push API aracılığıyla Chrome uzantıları yer alır.
FCM SDK yalnızca HTTPS üzerinden sunulan sayfalarda desteklenir. Bunun nedeni, yalnızca HTTPS sitelerinde kullanılabilen hizmet çalışanlarını kullanmasıdır. Bir sağlayıcıya ihtiyacınız varsa Firebase Hosting önerilir. Bu hizmet, kendi alanınızda HTTPS barındırma için ücretsiz bir katman sunar.
FCM JavaScript API'yi kullanmaya başlamak için web uygulamanıza Firebase'i eklemeniz ve kayıt jetonlarına erişmek için mantık eklemeniz gerekir.
FCM SDK'sını ekleme ve başlatma
Henüz yapmadıysanız Firebase JS SDK'yı yükleyin ve Firebase'i başlatın.
Firebase Cloud Messaging JS SDK'sını ekleyin ve Firebase Cloud Messaging başlatın:
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();
Şu anda web için FCM kullanıyorsanız ve SDK 6.7.0 veya sonraki bir sürüme yükseltmek istiyorsanız Google Cloud Console'da projeniz için FCM Registration API'yi etkinleştirmeniz gerekir. API'yi etkinleştirirken Firebase için kullandığınız Google Hesabı ile Cloud Console'a giriş yaptığınızdan ve doğru projeyi seçtiğinizden emin olun. FCM SDK'sını ekleyen yeni projelerde bu API varsayılan olarak etkindir.
FCM ile web kimlik bilgilerini yapılandırma
FCM Web arayüzü, desteklenen web push hizmetlerine gönderme isteklerini yetkilendirmek için "Gönüllü Uygulama Sunucusu Tanımlama" veya "VAPID" anahtarları olarak adlandırılan web kimlik bilgilerini kullanır. Uygulamanızı push bildirimlerine abone etmek için Firebase projenizle bir anahtar çifti ilişkilendirmeniz gerekir. Firebase Console üzerinden yeni bir anahtar çifti oluşturabilir veya mevcut anahtar çiftinizi içe aktarabilirsiniz.
Yeni bir anahtar çifti oluşturma
- Firebase konsolunun Ayarlar bölmesindeki Cloud Messaging sekmesini açın ve Web yapılandırması bölümüne gidin.
- Web Push sertifikaları sekmesinde Anahtar Çifti Oluştur'u tıklayın. Konsolda, anahtar çiftinin oluşturulduğuyla ilgili bir bildirim ve ortak anahtar dizesi ile eklenme tarihi gösterilir.
Mevcut bir anahtar çiftini içe aktarma
Web uygulamanızla zaten kullandığınız mevcut bir anahtar çiftiniz varsa FCM API'leri aracılığıyla mevcut web uygulaması örneklerinize ulaşabilmek için bu anahtar çiftini FCM'ye aktarabilirsiniz. Anahtarları içe aktarmak için Firebase projesine sahip düzeyinde erişiminiz olmalıdır. Mevcut ortak ve özel anahtarınızı Base64 URL güvenli kodlu biçimde içe aktarın:
- Firebase konsolunun Ayarlar bölmesindeki Cloud Messaging sekmesini açın ve Web yapılandırması bölümüne gidin.
- Web Push sertifikaları sekmesinde "Mevcut bir anahtar çiftini içe aktar" bağlantı metnini bulup seçin.
- Anahtar çiftini içe aktar iletişim kutusunda, ortak ve özel anahtarlarınızı ilgili alanlara girin ve İçe aktar'ı tıklayın. Konsolda ortak anahtar dizesi ve eklenme tarihi gösterilir.
Anahtarı uygulamanıza nasıl ekleyeceğinizle ilgili talimatlar için Uygulamanızda web kimlik bilgilerini yapılandırma başlıklı makaleyi inceleyin. Anahtarların biçimi ve nasıl oluşturulacağı hakkında daha fazla bilgi için Uygulama sunucusu anahtarları başlıklı makaleyi inceleyin.
Uygulamanızda web kimlik bilgilerini yapılandırma
getToken(): Promise<string>
yöntemi, FCM'nin farklı push hizmetlerine mesaj isteği gönderirken VAPID anahtarı kimlik bilgisini kullanmasına olanak tanır. Web kimlik bilgilerini FCM ile yapılandırma bölümündeki talimatlara göre oluşturduğunuz veya içe aktardığınız anahtarı kullanarak, mesajlaşma nesnesi alındıktan sonra kodunuza ekleyin:
import { getMessaging, getToken } from "firebase/messaging";
const messaging = getMessaging();
// Add the public key generated from the console here.
getToken(messaging, {vapidKey: "BKagOny0KF_2pCJQ3m....moL0ewzQ8rZu"});
Kayıt jetonuna erişme
Bir uygulama örneği için mevcut kayıt jetonunu almanız gerektiğinde önce Notification.requestPermission()
ile kullanıcıdan bildirim izinleri isteyin.
Gösterildiği gibi çağrıldığında, izin verilirse jeton döndürür veya izin verilmezse sözü reddeder:
function requestPermission() { console.log('Requesting permission...'); Notification.requestPermission().then((permission) => { if (permission === 'granted') { console.log('Notification permission granted.');
FCM için firebase-messaging-sw.js
dosyası gerekir.
Henüz bir firebase-messaging-sw.js
dosyanız yoksa bu ada sahip boş bir dosya oluşturun ve jeton almadan önce alanınızın kök dizinine yerleştirin.
Daha sonra istemci kurulumu sırasında dosyaya anlamlı içerik ekleyebilirsiniz.
Mevcut jetonu almak için:
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); // ... });
Jetonu aldıktan sonra uygulama sunucunuza gönderin ve tercih ettiğiniz yöntemi kullanarak saklayın.
Sonraki adımlar
Kurulum adımlarını tamamladıktan sonra FCM for Web (JavaScript) ile ilerlemek için kullanabileceğiniz birkaç seçenek aşağıda verilmiştir:
- Uygulamanıza mesaj alma işlevi ekleyin.
- Eğitimlerimizden birini deneyin: Arka Planda Çalışan Bir Uygulamaya İlk Mesajınızı Gönderme veya Birden Fazla Cihaza Mesaj Gönderme.
- GitHub'daki örneklerin tamamını inceleyin.
- JavaScript referansını inceleyin.
- API'nin uygulanmasıyla ilgili video adım adım açıklamalı kılavuzunu izleyin.