Pesan push multicast pertama Anda menggunakan topik FCM

1. Pengantar

Sasaran

Dalam codelab ini, Anda akan mempelajari cara menginstrumentasi aplikasi multiplatform sehingga Anda dapat mengirim pesan push multicast ke berbagai subgrup instance aplikasi menggunakan topik FCM.

Setelah selesai, Anda akan dapat memanfaatkan infrastruktur FCM untuk mengelola subgrup ini serta mengirimkan pesan push multicast melalui subgrup.

Ringkasan Topik

Topik adalah cara yang didukung infrastruktur FCM untuk menjangkau subgrup instance aplikasi Anda dengan pesan.

FCM menyediakan API untuk mengirim pesan serta mempertahankan langganan ke topik ini. Tindakan mengaitkan dan membatalkan kaitan instance aplikasi ke topik disebut berlangganan dan berhenti berlangganan

Topik harus digunakan untuk konten yang tersedia secara publik. Misalnya, pesan tentang info cuaca terbaru. Jika Anda ingin mengirim pesan yang berisi informasi sensitif pengguna, gunakan Firebase Admin SDK untuk mengirim pesan ke beberapa perangkat.

Multicast berbasis topik dioptimalkan untuk throughput.

Hal yang akan Anda pelajari

  • Cara membuat pengguna berlangganan (dan berhenti berlangganan) topik dari aplikasi seluler.
  • Cara mengirim pesan push multicast menggunakan topik.
  • Cara mengirim pesan ke kombinasi topik menggunakan kondisi topik.
  • Cara mengelola langganan topik di sisi server serta melakukan langganan dan pembatalan langganan massal.

Hal yang akan Anda build

  • Aplikasi Android yang berlangganan/berhenti berlangganan topik dan menerima pesan saat dikirim ke topik.
  • Integrasi sisi server menggunakan Firebase Admin SDK, yang akan digunakan untuk mengirim pesan topik melalui FCM API.

Hal yang akan Anda perlukan

  • Browser pilihan Anda, seperti Chrome.
  • IDE IntelliJ IDEA untuk mengembangkan aplikasi Java.
    • Pastikan untuk mengaktifkan dukungan untuk Gradle saat menginstal.
  • IDE Android Studio untuk mengembangkan aplikasi Android.
  • Perangkat untuk menjalankan aplikasi Android. Salah satu dari:
    • Emulator Android. (Memerlukan penyiapan di Android Studio).
    • Perangkat Android fisik yang terhubung ke komputer dan disetel ke mode developer.
  • Akun Google untuk membuat dan mengelola project Firebase Anda.

2. Mempersiapkan

Mendapatkan kode

Buat clone repositori GitHub dari command line:

git clone https://github.com/firebase/quickstart-android.git fcm-codelab

Kode contoh akan di-clone ke direktori fcm-codelab.

cd fcm-codelab

Aplikasi awal untuk codelab ini ada di direktori messaging pada cabang fcm-topics-codelab. Lakukan langkah-langkah berikut untuk mengakses kode awal. Direktori ini berisi dua direktori, yaitu StockNewsApp dan StockNewsServer. Yang pertama berisi Aplikasi Android awal dan yang kedua memiliki kode sisi server awal.

git checkout fcm-topics-codelab
cd messaging/fcm-topics-codelab/starter

Versi lengkap codelab ini ditempatkan di direktori messaging/fcm-topics-codelab/completed.

Membuat project Firebase

  1. Login ke Firebase console menggunakan Akun Google Anda.
  2. Klik tombol untuk membuat project baru, lalu masukkan nama project (misalnya, StockNews).
  3. Klik Lanjutkan.
  4. Jika diminta, tinjau dan setujui persyaratan Firebase, lalu klik Continue.
  5. (Opsional) Aktifkan bantuan AI di Firebase console (disebut "Gemini di Firebase").
  6. Untuk codelab ini, Anda tidak memerlukan Google Analytics, jadi nonaktifkan opsi Google Analytics.
  7. Klik Buat project, tunggu hingga project Anda disediakan, lalu klik Lanjutkan.

Selamat! Anda baru saja membuat project Firebase.

3. Konfigurasi aplikasi Firebase khusus platform

Sebagian besar perubahan kode yang diperlukan untuk mengaktifkan dukungan Firebase sudah diperiksa di project yang sedang Anda kerjakan. Namun, guna menambahkan dukungan untuk platform seluler, Anda perlu:

  • Daftarkan platform yang diinginkan di project Firebase
  • Download file konfigurasi khusus platform, lalu tambahkan file ke kode.

Untuk tujuan codelab ini, kita akan menambahkan aplikasi Firebase Android.

84e0b3199bef6d8a.pngMengonfigurasi Android

  1. Di Firebase Console, pilih Project Settings di bagian atas menu navigasi sebelah kiri di roda gigi Settings, lalu klik ikon Android di bagian Your apps di halaman General.

Anda akan melihat dialog berikut : 8254fc299e82f528.png

  1. Nilai penting yang harus diberikan adalah Nama paket Android. Tetapkan ke com.ticker.stocknews.
    1. Nama paket yang diberikan di sini harus sama dengan yang diberikan di AndroidManifest.xml kode StockNewsApp pemula Anda. Jika Anda ingin menemukan atau mengubahnya, ikuti langkah-langkah berikut:
      1. Di direktori StockNewsApp, buka file app/src/main/AndroidManifest.xml.
      2. Di elemen manifest, temukan nilai string atribut package. Nilai ini adalah nama paket Android.
  1. Di dialog Firebase, tempel nama paket yang disalin ke kolom Nama paket Android.
  2. Anda tidak memerlukan Sertifikat penandatanganan debug SHA-1 untuk codelab ini, karena aplikasi ini tidak akan dirilis. Kosongkan kolom ini.
  3. Klik Daftarkan Aplikasi.
  4. Melanjutkan di Firebase Console, ikuti petunjuk untuk mendownload file konfigurasi google-services.json.
  5. Anda dapat melewati langkah penyiapan lainnya, karena semuanya sudah dikonfigurasi dalam kode aplikasi starter. Anda akan menemukan aplikasi Anda yang tercantum di halaman utama Firebase Console.
  6. Salin file google-services.json (yang baru saja Anda download) ke direktori messaging/fcm-topics-codelab/starter/StockNewsApp/app.

4. Buat dan jalankan aplikasi Anda

Anda sudah siap untuk membuat aplikasi Anda sendiri. Pertama, bangun dan jalankan aplikasi.

Mengimpor aplikasi awal

Mulai Android Studio, lalu impor messaging/fcm-topics-codelab/starter/StockNewsApp dari direktori kode awal.

Setelah project dimuat, Anda juga akan melihat notifikasi bahwa Git tidak melacak semua perubahan lokal. Anda dapat mengklik "Ignore" atau "X" di kanan atas. (Anda tidak akan mendorong perubahan apa pun kembali ke repositori Git.)

Di sudut kiri atas jendela project, Anda akan melihat sesuatu seperti gambar di bawah jika berada dalam tampilan Android. (Jika berada dalam tampilan Project, Anda harus memperluas project untuk melihat hal yang sama)

b574ea0089ee87c6.png

Perlu diketahui bahwa Android Studio mungkin memerlukan waktu beberapa detik untuk mengompilasi project di latar belakang untuk pertama kalinya. Selama durasi ini, Anda akan melihat indikator lingkaran berputar di status bar di bagian bawah Android Studio:

4bc64eb3b99eb0ae.png

Sebaiknya Anda menunggu hingga proses ini selesai sebelum memodifikasi kode. Tindakan ini akan memungkinkan Android Studio menarik semua komponen yang diperlukan.

Selain itu, jika Anda ditanya "Reload for language changes to take effect?" atau yang serupa, pilih "Yes".

Penyiapan Emulator

Jika Anda memerlukan bantuan untuk menyiapkan emulator Android, lihat artikel Menjalankan aplikasi Anda.

Memahami kode awal Aplikasi Android

  • Kode awal adalah Aplikasi Android ringan dengan fungsi dan UI minimal.
  • Dependensi ke Firebase Cloud Messaging SDK sudah ditambahkan ke file app/build.gradle.

f04ff8f48d186dff.png

  • Di AndroidManifest.xml, pengendali callback MESSAGING_EVENT sudah ditambahkan.
    • Handler ini, StockNewsMessagingService.java memperluas class FirebaseMessagingService yang menyediakan berbagai fungsi terkait Firebase Cloud Messaging. Lihat dokumentasi FirebaseMessagingService untuk mempelajari lebih lanjut. b843c4d33ee53166.png
    88fad1960f4a6ff5.png
    • Fungsi onNewToken dipanggil saat Token Pendaftaran FCM dibuat atau diperbarui. Lihat Memantau pembuatan token untuk mengetahui informasi selengkapnya.
    • Fungsi onMessageReceived dipanggil saat pesan diterima dan aplikasi berada di latar depan. Saat ini, pesan yang diterima hanya dicatat.
  • Selain itu, di AndroidManifest.xml, class Application Android juga disediakan dengan nama StockNewsApplication. a4982a8731492dfc.pngccde692f7f68dc5a.png
    • Class ini akan menjadi class pertama yang dibuat instance-nya saat Aplikasi dimulai.
    • Di fungsi onCreate class StockNewsApplication, panggilan pembuatan Token Pendaftaran FCM ditambahkan. Kode ini akan membuat Token Pendaftaran FCM yang valid dan mencatatnya.
  • MainActivity.java menambahkan RecyclerView yang menampilkan pilihan Kategori Stok.
  • SubscriptionAdapter.java mengimplementasikan RecyclerView.Adapter yang menggambar layar pemilihan Kategori Saham.
    • Setiap Kategori Saham memiliki nama dan tombol langganan di sampingnya.
    • Mengubah tombol harus melakukan panggilan langganan / berhenti berlangganan topik FCM.
    • Anda akan menerapkan panggilan ini di bagian berikutnya.
  • Class model/StockCategories.java berisi daftar semua Kategori Saham dan nama topik terkaitnya.

b32663ec4e865a18.png

Menjalankan aplikasi awal

  1. Hubungkan perangkat Android ke komputer atau mulai emulator.
  2. Di toolbar atas, pilih perangkat Android atau emulator target Anda, lalu tekan tombol jalankan.

5b27fc5b237e06b9.png

  1. UI Aplikasi akan terlihat seperti berikut:

ff5b1a1c53231c54.png

  1. Aplikasi akan membuat dan mencatat Token Pendaftaran FCM. Namun, tidak ada yang akan berubah di UI Aplikasi.
    1. Salin dan simpan Token Pendaftaran FCM karena akan digunakan pada langkah berikutnya.

927eb66bc909f36b.png

5. Mengirim Pesan Pengujian

Sekarang Anda siap mengirim pesan pengujian ke instance aplikasi yang telah Anda siapkan di langkah terakhir.

Mengimpor kode server awal

Mulai IntelliJ IDEA dan buka project messaging/fcm-topics-codelab/starter/StockNewsServer.

Tampilan project di panel navigasi kiri Anda akan terlihat seperti ini:

da20711f6527dff6.png

Perhatikan, mungkin diperlukan waktu beberapa menit bagi IntelliJ IDEA untuk membangun project Anda, termasuk menarik dependensi yang diperlukan.

Memahami kode awal server

  • Kode awal server adalah project Java berbasis Gradle.
  • File build.gradle sudah memiliki dependensi pada Firebase Admin SDK yang ditambahkan ke dalamnya. SDK ini memberikan akses ke berbagai fungsi pengiriman pesan FCM.

650fc733298588f8.png

  • Terakhir, ada dua class, yaitu:
    • FcmSender.java: Class ini berisi metode penting berikut:
      • initFirebaseSDK: Melakukan inisialisasi firebase-admin SDK.
      • sendMessageToFcmRegistrationToken: mengirim pesan ke Token Pendaftaran FCM.
      • sendMessageToFcmTopic: mengirim pesan ke topik FCM.
      • sendMessageToFcmTopicCondition: mengirim pesan ke kondisi topik FCM.
    • FcmSubscriptionManager.java: Class ini berisi metode yang memungkinkan pengelolaan langganan topik dari sisi server.
      • initFirebaseSDK: Melakukan inisialisasi firebase-admin SDK.
      • subscribeFcmRegistrationTokensToTopic: membuat Token Pendaftaran FCM berlangganan topik FCM.
      • unsubscribeFcmRegistrationTokensFromTopic: menghentikan langganan Token Pendaftaran FCM dari topik FCM.

Menyiapkan kode server

  1. Pertama, kita perlu menyiapkan Akun Layanan Firebase yang memungkinkan SDK firebase-admin mengizinkan panggilan ke FCM API.
    1. Buka Konsol Firebase, klik ikon roda gigi di samping Project Overview di menu navigasi sebelah kiri, lalu pilih Project settings. 8c2108d4d7c915e9.png
    2. Di halaman setelan, pilih Akun layanan, lalu klik Buat akun layanan. 84b128cc5dac0a85.png
    3. Sekarang klik tombol Generate new private key dan download otomatis file kunci Anda akan dimulai.
    4. Ganti nama file kunci menjadi service-account.json dan salin ke folder messaging/fcm-topics-codelab/starter/StockNewsServer/src/main/resources.
    5. FcmSender.java dan FcmSubscriptionManager.java memuat file service-account.json dari classpath menggunakan kode berikut. 8dffbee658e0bdd.png
  2. Pada tahap ini, kode server sudah siap. Jalankan Build -> Build Project dari panel menu atas.

Mengirim Pesan Pengujian

  1. Di FcmSender.java, temukan fungsi sendMessageToFcmRegistrationToken dan masukkan token pendaftaran FCM yang Anda salin dari bagian Jalankan aplikasi awal ke dalam kolom registrationToken.
  2. Dalam fungsi main, hapus komentar hanya pada fungsi sendMessageToFcmRegistrationToken, lalu klik jalankan untuk mengeksekusi kode.
    1. Perhatikan cara Token Pendaftaran FCM ditetapkan ke kolom Token objek message.
    2. Selain itu, perhatikan cara kita menggunakan API send dari antarmuka FirebaseMessaging.

52e4a3ec3f816473.png

  1. Tindakan ini akan mengirim pesan ke instance aplikasi yang telah Anda siapkan pada langkah sebelumnya.
  2. Saat instance aplikasi berada di latar depan, Anda akan melihat konten pesan yang dicatat.

d3540ec1089f97dd.png

  1. Saat instance Aplikasi berada di latar belakang, Anda akan melihat pesan muncul di area notifikasi.

31203deca59c03fe.png

Hebat, Anda telah menggunakan Firebase Admin SDK untuk mengirim pesan ke instance aplikasi. Baca selengkapnya tentang penggunaan Firebase Admin SDK di server Anda.

6. Menerapkan Berlangganan / Berhenti Berlangganan Topik

Pada langkah ini, Anda akan menerapkan tindakan berlangganan dan pembatalan langganan topik, pada tombol Kategori Saham di Aplikasi Android.

Saat pengguna Aplikasi mengalihkan tombol untuk Kategori Saham tertentu, panggilan berlangganan atau berhenti berlangganan topik akan dilakukan.

Tinjau kode

  • Buka class SubscriptionAdapter.java di kode Aplikasi Android dan temukan class RecyclerViewViewHolder.

6c0614199e684f6.png

  • Konstruktor kelas menyiapkan pemroses untuk tombol langganan menggunakan setOnCheckedChangeListener.
  • Bergantung pada tombol pengalih, tindakan berlangganan dan berhenti berlangganan dilakukan dengan memanggil metode subscribeToStockCategory dan unsubscribeFromStockCategory.
  • Metode setData dipanggil oleh onBindViewHolder Adaptor RecyclerView untuk mengikat ViewHolder dengan Kategori Saham yang sesuai.

Menerapkan langganan topik

  1. Dalam metode subscribeToStockCategory, Anda akan menerapkan panggilan ke API subscribeToTopic objek FirebaseMessaging. Kodenya bisa terlihat seperti ini:
   void subscribeToStockCategory() {
      // Making call to FCM for subscribing to the topic for stockCategory
     FirebaseMessaging.getInstance().subscribeToTopic(stockCategory.getTopicName()).addOnSuccessListener(
          unused -> {
            // Subscribing action successful
            Log.i(TAG, "Subscribed to topic: " + stockCategory.getTopicName());
            Toast.makeText(itemView.getContext(), "Subscribed to " + stockCategory.getCategoryName(),
                Toast.LENGTH_SHORT).show();
          });
    }

Menerapkan berhenti berlangganan topik

  1. Demikian pula, dalam kondisi else, Anda akan menerapkan panggilan ke API unsubscribeFromTopic. Berikut contohnya:
void unsubscribeFromStockCategory() {
      // Making call to FCM for unsubscribing from the topic for stockCategory
      FirebaseMessaging.getInstance().unsubscribeFromTopic(stockCategory.getTopicName())
          .addOnSuccessListener(unused -> {
            // Unsubscribing action successful
            Log.i(TAG, "Unsubscribed from topic: " + stockCategory.getTopicName());
            Toast.makeText(itemView.getContext(), "Unsubscribed from " + stockCategory.getCategoryName(),
                Toast.LENGTH_SHORT).show();
          });
    }

Mari kita coba

  1. Jalankan Aplikasi dan aktifkan/nonaktifkan opsi Kategori Saham untuk menjalankan tindakan Berlangganan dan Berhenti Berlangganan. Tampilannya akan terlihat seperti ini:

Berlangganan

Berhenti berlangganan

7. Mengirim Pesan Topik pertama Anda

Pada langkah ini, Anda akan menerapkan kode sisi server untuk mengirim pesan topik FCM.

Menerapkan integrasi sisi server untuk mengirim pesan topik

  1. Di kode server, buka FcmSender.java dan temukan metode bernama sendMessageToFcmTopic.

56381dd1b40cde9c.png

  1. Di baris pertama, berikan Topik FCM yang ingin Anda kirimi pesan.
    • Ini adalah string dalam bentuk: /topics/<Topic Name>. Contoh, /topics/Technology.
  2. Di baris berikutnya, buat objek message baru (mirip dengan yang ditentukan dalam fungsi sendMessageToFcmRegistrationToken).
    • Perbedaannya adalah, alih-alih menetapkan kolom Token objek message, Anda akan menetapkan kolom Topic.
Message message = Message.builder()
        .putData("FOOTECH", "$1000")
        .setNotification(
            Notification.builder()
                .setTitle("Investor confidence in Tech Stocks growing")
                .setBody("Foo Tech leading the way in stock growth for Tech sector.")
                .build())
        .setTopic(topicName)
        .build();
  1. Sekarang tambahkan panggilan ke instance FirebaseMessaging untuk mengirim pesan (identik dengan panggilan pengiriman yang dilakukan dalam fungsi sendMessageToFcmRegistrationToken).
FirebaseMessaging.getInstance().send(message);
  1. Terakhir, perbarui fungsi main dan aktifkan panggilan ke hanya fungsi sendMessageToFcmTopic.

9a6aa08dd7c28898.png

Mengirim pesan dan memvalidasi penerimaan

  1. Sebelum mengirim pesan topik, pastikan terlebih dahulu bahwa instance aplikasi Anda telah berlangganan topik yang ingin Anda kirimi pesan.
    1. Hal ini dapat dilakukan dengan membalikkan tombol yang sesuai. Contoh:
    4668247408377712.png
  2. Sekarang Anda dapat mengirim pesan topik dengan menjalankan fungsi main dari FcmSender.java.
  3. Seperti sebelumnya, Anda akan dapat mengamati penerimaan pesan di instance aplikasi.
    1. Instance aplikasi di latar depan
    c144721399f610fe.png
    1. Instance aplikasi di latar belakang
    44efc7dfd57e8e9a.png
  4. Bonus: Coba berhenti berlangganan topik yang Anda kirimi pesan, lalu kirim ulang pesan. Anda akan melihat bahwa pesan tidak dikirim ke instance aplikasi.

8. Mengirim Pesan Kondisi Topik pertama Anda

Fitur kondisi topik memungkinkan Anda mengirim pesan ke kombinasi topik sehingga Anda dapat memberikan definisi audiens yang lebih ekspresif.

Misalnya, di Aplikasi StockNews kami, pertimbangkan kemungkinan mengirim pesan ke grup instance aplikasi yang berlangganan topik Teknologi atau Otomotif. Kasus seperti itu dapat terjadi, misalnya, jika ada peristiwa penting yang melibatkan Waymo.

Topics memungkinkan Anda menyatakan kombinasi dalam bentuk ekspresi boolean menggunakan operator berikut

  • && : AND logis. Misalnya, 'Technology' in topics && 'Automotive' in topics - Hanya menargetkan instance aplikasi yang berlangganan ke Topik Teknologi dan Otomotif.
  • || : OR Logis. Misalnya, 'Technology' in topics || 'Automotive' in topics - Menargetkan instance aplikasi yang berlangganan topik Teknologi atau Otomotif.
  • () : Tanda kurung untuk pengelompokan. Misalnya, 'Technology' in topics && ('Automotive' in topics || 'Energy' in topics) - Hanya menargetkan instance aplikasi yang berlangganan topik Technology dan Automotive atau Energy.

Baca selengkapnya tentang cara membuat permintaan pengiriman untuk menggunakan fungsi ini.

Menerapkan integrasi sisi server untuk mengirim pesan kondisi topik

  1. Kembali ke kode server, buka FcmSender.java dan temukan metode bernama sendMessageToFcmTopicCondition.

3719a86c274522cf.png

  1. Di baris pertama, untuk variabel topicCondition, berikan kondisi topik yang ingin Anda kirimi pesan. Anda dapat menyetelnya ke: 'Technology' in topics && 'Automotive' in topics.
  2. Di baris berikutnya, buat objek message baru (mirip dengan yang ditentukan dalam fungsi sendMessageToFcmTopic).
    1. Perbedaannya adalah, alih-alih menetapkan kolom Topic objek, Anda akan menetapkan kolom Condition.
    Message message = Message.builder()
        .putData("FOOCAR", "$500")
        .setNotification(
            Notification.builder()
                .setTitle("Foo Car shows strong Q2 results")
                .setBody("Foo Car crosses 1B miles. Stocks rally.")
                .build())
        .setCondition(topicCondition)
        .build();
  1. Sekarang tambahkan panggilan ke instance FirebaseMessaging untuk mengirim pesan (identik dengan panggilan pengiriman yang dilakukan dalam fungsi sendMessageToFcmTopic).
FirebaseMessaging.getInstance().send(message);
  1. Terakhir, perbarui fungsi main dan aktifkan panggilan ke hanya fungsi sendMessageToFcmTopicCondition.

db9588d40d2a0da6.png

Mengirim pesan dan memvalidasi penerimaan

  1. Sebelum mengirim pesan topik, pastikan terlebih dahulu instance aplikasi Anda memenuhi kondisi topik yang ditentukan dengan mendaftarkan instance aplikasi ke topik Technology dan Automotive.
  2. Sekarang Anda dapat mengirim pesan topik dengan menjalankan fungsi main dari FcmSender.java.
  3. Seperti sebelumnya, Anda akan dapat mengamati penerimaan pesan di instance aplikasi.
    1. Instance aplikasi di latar depan
    6f612ace15aa6515.png
    1. Instance aplikasi di latar belakang
    78044a56ac2359cb.png
  4. Bonus: Anda kini dapat berhenti berlangganan topik Teknologi dan mengirim ulang pesan kondisi topik. Anda akan melihat bahwa pesan tidak diterima oleh instance aplikasi.

9. Rangkuman

Mari kita rangkum secara singkat apa yang telah Anda pelajari hingga saat ini.

  • Cara memulai langganan / berhenti berlangganan topik dari instance aplikasi.
  • Mengirim pesan ke topik dan memverifikasi penerimaan pada instance aplikasi yang berlangganan.
  • Mengirim pesan ke kondisi topik dan memverifikasi penerimaan pada instance aplikasi yang memenuhi kondisi.

Di bagian berikutnya, Anda akan mempelajari cara berlangganan / berhenti berlangganan instance aplikasi ke topik tanpa perlu membuat panggilan dari sisi klien.

c0dc20655d392690.gif

10. Mengelola Langganan Topik dari Sisi Server

Hingga saat ini, dalam codelab ini, semua panggilan langganan dan berhenti berlangganan topik dimulai dari instance aplikasi.

Namun, dalam beberapa kasus penggunaan, Anda mungkin ingin mengelola langganan topik dari Sisi Server. Misalnya, Anda mungkin ingin mendaftarkan subgrup basis pengguna yang ada ke topik baru tanpa menunggu peluncuran aplikasi.

Di bagian ini, Anda akan mempelajari cara menggunakan Firebase Admin SDK untuk berlangganan dan berhenti berlangganan sekelompok Token Pendaftaran FCM ke topik dengan melakukan panggilan dari sisi server.

Menerapkan langganan sisi server Token Pendaftaran FCM ke topik FCM

  1. Dalam kode server, buka class FcmSubscriptionManager.java. Temukan metode bernama subscribeFcmRegistrationTokensToTopic. Anda akan menerapkan panggilan ke API subscribeToTopic di sini.

5d5709e7b3cbcb04.png

  1. Mari kita buat instance aplikasi berlangganan topik Energy. Untuk melakukannya, pertama-tama berikan data untuk dua kolom berikut:
    1. registrationTokens: daftar string yang dipisahkan koma yang merepresentasikan Token Pendaftaran FCM yang ingin Anda buat langganan topiknya.
    2. topicName: nama topik untuk topik Energi, yaitu /topics/Energy.
  2. Di beberapa baris berikutnya, terapkan panggilan, seperti berikut:
TopicManagementResponse response = FirebaseMessaging.getInstance().subscribeToTopic(
        registrationTokens, topicName);
  1. Anda dapat memeriksa TopicManagementResponse untuk melihat statistik hasil tingkat tinggi. Misalnya, mencetak jumlah langganan topik yang berhasil dibuat menggunakan getSuccessCount.
System.out.printf("Num tokens successfully subscribed %d", response.getSuccessCount());
  1. Terakhir, di fungsi main, aktifkan panggilan hanya ke fungsi subscribeFcmRegistrationTokensToTopic.

Membuat langganan dan mengirim pesan topik

  1. Pada tahap ini, Anda siap membuat langganan topik dan mengirim pesan ke topik tersebut.
  2. Jalankan fungsi main class FcmSubscriptionManager.java. Tindakan ini akan membuat langganan topik.
  3. Sekarang, siapkan kode untuk mengirim pesan. Seperti sebelumnya,
    1. Di FcmSender.java, temukan fungsi sendMessageToFcmTopic.
    2. Tetapkan topicName ke topik Energi, yaitu /topics/Energy.
    3. Buat objek Message dan targetkan ke topik menggunakan setTopic.
    4. Terakhir, perbarui metode main agar hanya mengaktifkan fungsi sendMessageToFcmTopic.
  4. Jalankan fungsi main dari FcmSender.java. Tindakan ini akan mengirim pesan ke instance aplikasi Anda dan Anda dapat mengamatinya di aplikasi Anda sebagai berikut.
    1. Instance aplikasi di latar depan
    40ab6cf71e0e4116.png
    1. Instance aplikasi di latar belakang
    8fba81037198209e.png

Menerapkan pembatalan langganan sisi server Token Pendaftaran FCM ke topik FCM

  1. Untuk berhenti berlangganan topik sisi server, gunakan unsubscribeFromTopic API ini. Anda akan menambahkan kode yang relevan ke fungsi unsubscribeFcmRegistrationTokensFromTopic class FcmSubscriptionManager.java.

8d9e8ea9d34016bd.png

  1. Penerapan kode berhenti berlangganan sisi server dan memvalidasi efeknya dengan mengirim pesan topik, diserahkan kepada Anda sebagai latihan.

11. Selamat

Selamat, Anda telah berhasil menggunakan topik FCM untuk mengirim pesan multicast ke subgrup instance aplikasi Anda. Cara ini akan membantu menyederhanakan kemampuan Anda untuk menjangkau pengguna secara tepat waktu dengan konten yang relevan.

947def3eb33b1e4a.gif

Apa langkah selanjutnya?

Setelah menyelesaikan codelab ini, coba topik untuk platform lain menggunakan panduan berikut:

Dokumen Referensi