वेब ऐप्लिकेशन में Firebase क्लाउड से मैसेज भेजने की सुविधा का इस्तेमाल शुरू करना

प्लैटफ़ॉर्म चुनें: iOS+ Android Web Flutter Unity C++


इस गाइड में बताया गया है कि वेब क्लाइंट ऐप्लिकेशन में Firebase Cloud Messaging का इस्तेमाल कैसे शुरू करें, ताकि भरोसेमंद तरीके से मैसेज भेजे जा सकें.

FCM JavaScript API की मदद से, आपको उन वेब ऐप्लिकेशन में सूचनाएं मिल सकती हैं जो Push API के साथ काम करने वाले ब्राउज़र में चलते हैं. इसमें, इस सहायता मैट्रिक्स में दिए गए ब्राउज़र के वर्शन और Push API का इस्तेमाल करने वाले Chrome एक्सटेंशन शामिल हैं.

FCM SDK का इस्तेमाल सिर्फ़ उन पेजों पर किया जा सकता है जो एचटीटीपीएस पर दिखाए जाते हैं. ऐसा इसलिए है, क्योंकि यह सेवा सर्विस वर्कर का इस्तेमाल करती है. ये सिर्फ़ एचटीटीपीएस साइटों पर उपलब्ध होते हैं. अगर आपको किसी सेवा देने वाली कंपनी की ज़रूरत है, तो Firebase App Hosting का इस्तेमाल करने का सुझाव दिया जाता है. यह कंपनी, आपके डोमेन पर एचटीटीपीएस होस्टिंग के लिए बिना किसी शुल्क वाली सेवा देती है.

FCM JavaScript API का इस्तेमाल शुरू करने के लिए, आपको अपने वेब ऐप्लिकेशन में Firebase जोड़ना होगा. साथ ही, Firebase इंस्टॉलेशन आईडी को ऐक्सेस करने के लिए लॉजिक जोड़ना होगा. इससे आपको सूचनाएं पाने वाले व्यक्ति को चुनने का विकल्प मिलता है.

FCM SDK टूल जोड़ना और उसे शुरू करना

  1. अगर आपने पहले से ऐसा नहीं किया है, तो Firebase JS SDK टूल इंस्टॉल करें और Firebase को शुरू करें.

  2. Firebase Cloud Messaging JS SDK जोड़ें और 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();

अगर आपको वेबसाइट के लिए FCM का इस्तेमाल करना है और SDK 6.7.0 या इसके बाद के वर्शन पर अपग्रेड करना है, तो आपको Google Cloud कंसोल में अपने प्रोजेक्ट के लिए FCM Registration API चालू करना होगा. एपीआई चालू करते समय, पक्का करें कि आपने उसी Google खाते से Google Cloud कंसोल में लॉग इन किया हो जिसका इस्तेमाल Firebase के लिए किया जाता है. साथ ही, यह भी पक्का करें कि आपने सही प्रोजेक्ट चुना हो. FCM SDK जोड़ने वाले नए प्रोजेक्ट के लिए, यह एपीआई डिफ़ॉल्ट रूप से चालू होता है.

FCM की मदद से, वेब क्रेडेंशियल कॉन्फ़िगर करना

FCM वेब इंटरफ़ेस, वेब क्रेडेंशियल का इस्तेमाल करता है. इन्हें वॉलंटरी ऐप्लिकेशन सर्वर आइडेंटिफ़िकेशन या VAPID कुंजियां कहा जाता है. इनकी मदद से, वेब पुश नोटिफ़िकेशन की सुविधा देने वाली सेवाओं को अनुरोध भेजने की अनुमति दी जाती है. अपने ऐप्लिकेशन को पुश नोटिफ़िकेशन पाने के लिए रजिस्टर करने के लिए, आपको अपने Firebase प्रोजेक्ट के साथ कुंजियों का एक जोड़ा जोड़ना होगा. Firebase कंसोल के ज़रिए, नया कुंजी जोड़ा जनरेट किया जा सकता है या मौजूदा कुंजी जोड़ा इंपोर्ट किया जा सकता है.

कुंजी के नए जोड़े को जनरेट करना

  1. Firebase कंसोल में, सेटिंग > सामान्य पर जाएं. इसके बाद, क्लाउड से मैसेज टैब पर क्लिक करें

  2. वेब कॉन्फ़िगरेशन सेक्शन पर जाएं.

  3. वेब पुश सर्टिफ़िकेट टैब में जाकर, कुंजी का जोड़ा जनरेट करें पर क्लिक करें.

    कंसोल में एक सूचना दिखती है, जिसमें बताया जाता है कि कुंजी का जोड़ा जनरेट हो गया है. साथ ही, इसमें सार्वजनिक पासकोड की स्ट्रिंग और उसे जोड़े जाने की तारीख दिखती है.

मौजूदा पासकोड इंपोर्ट करना

अगर आपके पास पहले से कोई कुंजी जोड़ी है और उसका इस्तेमाल वेब ऐप्लिकेशन के साथ किया जा रहा है, तो उसे FCM में इंपोर्ट किया जा सकता है. इससे FCM API के ज़रिए, अपने मौजूदा वेब ऐप्लिकेशन इंस्टेंस तक पहुंचा जा सकता है. कुंजियां इंपोर्ट करने के लिए, आपके पास Firebase प्रोजेक्ट के लिए मालिक के लेवल का ऐक्सेस होना चाहिए. अपनी मौजूदा सार्वजनिक और निजी कुंजी को base64 यूआरएल सेफ़ एन्कोड किए गए फ़ॉर्म में इंपोर्ट करें:

  1. Firebase कंसोल में, सेटिंग > सामान्य पर जाएं. इसके बाद, क्लाउड से मैसेज टैब पर क्लिक करें

  2. वेब कॉन्फ़िगरेशन सेक्शन पर जाएं.

  3. वेब पुश सर्टिफ़िकेट टैब में, लिंक टेक्स्ट ढूंढें और चुनें: मौजूदा कुंजी के जोड़े को इंपोर्ट करें.

  4. की का जोड़ा इंपोर्ट करें डायलॉग में, सार्वजनिक और निजी पासकोड को संबंधित फ़ील्ड में डालें. इसके बाद, इंपोर्ट करें पर क्लिक करें.

    कंसोल में, सार्वजनिक पासकोड स्ट्रिंग और उसे जोड़ने की तारीख दिखती है.

अपने ऐप्लिकेशन में कुंजी जोड़ने के तरीके के बारे में जानने के लिए, अपने ऐप्लिकेशन में वेब क्रेडेंशियल कॉन्फ़िगर करना लेख पढ़ें. कुंजियों के फ़ॉर्मैट और उन्हें जनरेट करने के तरीके के बारे में ज़्यादा जानने के लिए, ऐप्लिकेशन सर्वर की कुंजियां लेख पढ़ें.

अपने ऐप्लिकेशन में वेब क्रेडेंशियल कॉन्फ़िगर करना

register(): Promise<void> तरीके से, FCM को अलग-अलग पुश सेवाओं को मैसेज भेजने के अनुरोध करते समय, VAPID कुंजी क्रेडेंशियल का इस्तेमाल करने की अनुमति मिलती है. FCM के साथ वेब क्रेडेंशियल कॉन्फ़िगर करें में दिए गए निर्देशों के मुताबिक, जनरेट की गई या इंपोर्ट की गई कुंजी का इस्तेमाल करें. इसके बाद, मैसेजिंग ऑब्जेक्ट को वापस पाने के बाद, इसे अपने कोड में जोड़ें:

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"});

सूचना की अनुमति का अनुरोध करना और सर्विस वर्कर को कॉन्फ़िगर करना

जब आपको FCM की मदद से किसी ऐप्लिकेशन इंस्टेंस को टारगेट करना हो, तो सबसे पहले Notification.requestPermission() की मदद से उपयोगकर्ता से सूचनाओं की अनुमतियों का अनुरोध करें. दिखाए गए तरीके से कॉल करने पर, अनुमति मिलने पर यह अनुमति की स्थिति दिखाता है:

function requestPermission() {
  console.log('Requesting permission...');
  Notification.requestPermission().then((permission) => {
    if (permission === 'granted') {
      console.log('Notification permission granted.');
    }
  });
}

FCM के लिए, firebase-messaging-sw.js फ़ाइल की ज़रूरत होती है. अगर आपके पास पहले से firebase-messaging-sw.js फ़ाइल नहीं है, तो उस नाम की एक खाली फ़ाइल बनाएं और रजिस्टर करने से पहले, उसे अपने डोमेन के रूट में रखें. क्लाइंट सेटअप करने की प्रोसेस के दौरान, फ़ाइल में काम का कॉन्टेंट बाद में जोड़ा जा सकता है.

Firebase इंस्टॉलेशन आईडी को ऐक्सेस करना

ऐप्लिकेशन इंस्टेंस को रजिस्टर करने और मैसेज टारगेटिंग के लिए Firebase इंस्टॉलेशन आईडी (एफ़आईडी) पाने के लिए:

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);
});

onRegistered कॉलबैक इन तीन स्थितियों में ट्रिगर होता है:

  1. मैन्युअल register() कॉल खत्म होने पर.
  2. Firebase इंस्टॉलेशन आईडी में बदलाव का पता चला है.
  3. A pushsubscriptionchange इवेंट शुरू हो जाता है.

Firebase इंस्टॉलेशन आईडी मिलने के बाद, इसे अपने ऐप्लिकेशन सर्वर पर भेजें और अपनी पसंद के तरीके का इस्तेमाल करके इसे सेव करें.

रजिस्ट्रेशन टोकन ऐक्सेस करना (अब उपलब्ध नहीं है)

मौजूदा टोकन वापस पाने के लिए:

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);
  // ...
});

टोकन मिलने के बाद, इसे अपने ऐप्लिकेशन सर्वर पर भेजें और अपनी पसंद के तरीके से सेव करें.

टेस्ट के तौर पर सूचना वाला मैसेज भेजना

  1. टारगेट डिवाइस पर ऐप्लिकेशन इंस्टॉल करें और उसे चलाएं. Apple डिवाइसों पर, आपको रिमोट सूचनाएं पाने की अनुमति देने का अनुरोध स्वीकार करना होगा.

  2. देख लें कि ऐप्लिकेशन डिवाइस पर बैकग्राउंड में चल रहा हो.

  3. Firebase console में, DevOps & Engagement > Messaging पर जाएं

  4. कोई कैंपेन बनाएं.

    • अगर यह आपका पहला मैसेज है, तो:

      1. अपना पहला कैंपेन बनाएं को चुनें.

      2. Firebase सूचना वाले मैसेज को चुनें. इसके बाद, बनाएं को चुनें.

    • अगर आपने पहले कैंपेन बनाए हैं, तो:

      1. कैंपेन टैब पर, नया कैंपेन चुनें.

      2. सूचनाएं पर क्लिक करें.

  5. मैसेज का टेक्स्ट डालें.

  6. दाएं पैनल में मौजूद, टेस्ट मैसेज भेजें को चुनें.

  7. FCM रजिस्ट्रेशन टोकन जोड़ें लेबल वाले फ़ील्ड में, अपना रजिस्ट्रेशन टोकन डालें.

  8. जांचें को चुनें.

जांच करें को चुनने के बाद, टारगेट किए गए क्लाइंट डिवाइस पर सूचना मिलनी चाहिए. इस दौरान, ऐप्लिकेशन बैकग्राउंड में चल रहा हो.

अगले चरण

सेटअप के चरण पूरे करने के बाद, FCM for Web (JavaScript) का इस्तेमाल शुरू करने के लिए यहां कुछ विकल्प दिए गए हैं: