1. Pengantar
Sasaran
Dalam codelab ini, Anda akan mempelajari cara membuat instrumentasi 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 pesan push multicast melalui subgrup.
Ringkasan Topik
Topik adalah cara yang didukung infrastruktur FCM untuk menjangkau subgrup instance aplikasi dengan pesan.
FCM menyediakan API untuk mengirim pesan serta mempertahankan langganan ke topik ini. Tindakan mengaitkan dan membatalkan pengaitan instance aplikasi ke topik masing-masing disebut berlangganan dan berhenti berlangganan
Topik harus digunakan untuk konten yang tersedia untuk publik. Misalnya, pesan tentang info cuaca terbaru. Jika Anda ingin mengirim pesan yang sensitif kepada pengguna, gunakan Firebase Admin SDK untuk melakukan beberapa transmisi pesan melalui beberapa perangkat.
Multicasting berbasis topik dioptimalkan untuk throughput.
Hal yang akan Anda pelajari
- Cara membuat pengguna berlangganan topik dari aplikasi seluler (dan membuat mereka berhenti berlangganan).
- 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 massal dan pembatalan langganan.
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.
- IntelliJ IDEA IDE untuk mengembangkan aplikasi Java.
- Pastikan untuk memilih ikut serta dalam 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
dari cabang fcm-topics-codelab
. Lakukan langkah-langkah berikut untuk membuka kode awal. File ini berisi dua direktori, 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
- Di Firebase console, klik Tambahkan project, beri nama project Firebase StockNews, lalu klik lanjutkan. Catatan: Jangan lupa dengan Project ID untuk project Firebase Anda (atau klik ikon Edit untuk menetapkan Project ID pilihan Anda).
- Anda dapat melewati pengaktifan Google Analytics. Untuk tujuan codelab ini, Anda tidak memerlukannya. Klik Lanjutkan.
- Klik Create project.
Selamat! Anda baru saja membuat project Firebase. Sekarang, Anda dapat mengklik nama project untuk masuk ke konsol.
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, untuk menambahkan dukungan untuk platform seluler, Anda harus:
- 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.
Mengonfigurasi Android
- Di Firebase Console, pilih Project Settings di bagian atas menu navigasi kiri di roda gigi Setelan, lalu klik ikon Android di bagian Your apps di halaman General.
Anda akan melihat dialog berikut:
- Nilai penting yang harus diberikan adalah nama paket Android. Tetapkan ke
com.ticker.stocknews
.- Nama paket yang diberikan di sini harus sama dengan yang diberikan dalam
AndroidManifest.xml
kode StockNewsApp awal Anda. Jika Anda ingin menemukan atau mengubahnya, ikuti langkah-langkah berikut:- Di direktori StockNewsApp, buka file
app/src/main/AndroidManifest.xml
. - Dalam elemen
manifest
, temukan nilai string atributpackage
. Nilai ini adalah nama paket Android.
- Di direktori StockNewsApp, buka file
- Nama paket yang diberikan di sini harus sama dengan yang diberikan dalam
- Di dialog Firebase, tempel nama paket yang disalin ke kolom Nama paket Android.
- Anda tidak memerlukan Sertifikat penandatanganan debug SHA-1 untuk codelab ini, karena aplikasi ini tidak akan dirilis. Biarkan kosong.
- Klik Daftarkan Aplikasi.
- Melanjutkan di Firebase Console, ikuti petunjuk untuk mendownload file konfigurasi
google-services.json
. - Anda dapat melewati langkah-langkah penyiapan yang tersisa, karena yang lainnya sudah dikonfigurasi di kode aplikasi awal. Anda akan menemukan aplikasi tercantum di halaman utama Firebase Console.
- Salin file
google-services.json
(yang baru saja Anda download) ke direktorimessaging/fcm-topics-codelab/starter/StockNewsApp/app
.
4. Buat dan jalankan aplikasi Anda
Anda sudah siap untuk membuat aplikasi Anda sendiri. Pertama, build dan jalankan aplikasi.
Mengimpor aplikasi awal
Mulai Android Studio, dan 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 gambar seperti gambar di bawah ini jika berada dalam tampilan Android. (Jika berada dalam tampilan Project, Anda harus memperluas project untuk melihat hal yang sama)
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:
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.
Memahami kode awal Aplikasi Android
- Kode awal adalah Aplikasi Android ringan dengan fungsi dan UI minimal.
- Dependensi untuk firebase-Messaging SDK sudah ditambahkan ke file
app/build.gradle
.
- Di
AndroidManifest.xml
, pengendali callbackMESSAGING_EVENT
sudah ditambahkan.- Pengendali ini,
StockNewsMessagingService.java
memperluas classFirebaseMessagingService
yang menyediakan berbagai fungsi terkait Firebase Cloud Messaging. Lihat dokumentasi FirebaseMessagingService untuk mempelajari lebih lanjut.
- 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, fungsi ini hanya mencatat pesan yang diterima ke dalam log.- Lihat Menerima pesan di aplikasi Android untuk mempelajari lebih lanjut perbedaan antara pengiriman dan penanganan pesan latar belakang dan latar depan.
- Pengendali ini,
- Selain itu, di
AndroidManifest.xml
, classApplication
Android juga disediakan bernamaStockNewsApplication
.- Class ini akan menjadi class pertama yang dibuat instance-nya saat Aplikasi dimulai.
- Dalam fungsi
onCreate
classStockNewsApplication
, panggilan pembuatan Token Pendaftaran FCM ditambahkan. Tindakan ini akan menghasilkan Token Pendaftaran FCM yang valid dan mencatatnya ke dalam log.
MainActivity.java
menambahkanRecyclerView
yang menampilkan pilihan Kategori Stok.SubscriptionAdapter.java
menerapkanRecyclerView.Adapter
yang menggambar layar pemilihan Kategori Saham.- Setiap Kategori Saham memiliki nama dan tombol langganan di sampingnya.
- Mengubah tombol ini akan membuat panggilan langganan / berhenti berlangganan topik FCM.
- Anda akan menerapkan panggilan ini di bagian mendatang.
- Class
model/StockCategories.java
berisi daftar semua Kategori Saham dan nama topik terkaitnya.
Menjalankan aplikasi awal
- Hubungkan perangkat Android ke komputer atau mulai emulator.
- Di toolbar atas, pilih perangkat Android atau emulator target, lalu tekan tombol run.
- UI Aplikasi akan terlihat seperti berikut:
- Aplikasi akan membuat Token Pendaftaran FCM dan mencatatnya dalam log. Namun, tidak ada yang akan berubah di UI Aplikasi.
- Salin dan simpan Token Pendaftaran FCM karena akan digunakan pada langkah berikutnya.
5. Mengirim Pesan Pengujian
Sekarang Anda siap untuk mengirim pesan pengujian ke instance aplikasi yang telah disiapkan di langkah terakhir.
Mengimpor kode server awal
Mulai IntelliJ IDEA dan buka project messaging/fcm-topics-codelab/starter/StockNewsServer
.
Tampilan project di menu navigasi sebelah kiri akan terlihat seperti ini:
Perhatikan bahwa mungkin perlu 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.
- Terakhir, ada dua class, yaitu:
FcmSender.java
: Class ini berisi metode catatan 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
: berlanggananlah Token Pendaftaran FCM ke topik FCM.unsubscribeFcmRegistrationTokensFromTopic
: menghentikan langganan Token Pendaftaran FCM dari topik FCM.
Menyiapkan kode server
- Pertama, kita perlu menyiapkan Akun Layanan Firebase yang memungkinkan firebase-admin SDK untuk mengizinkan panggilan ke FCM API.
- Buka Firebase Console, klik ikon roda gigi di samping Project Overview di menu navigasi sebelah kiri, lalu pilih Project settings.
- Di halaman setelan, pilih Akun layanan dan klik Buat akun layanan.
- Sekarang klik tombol Generate new private key dan download otomatis file kunci Anda akan dimulai.
- Ganti nama file kunci menjadi
service-account.json
, lalu salin di foldermessaging/fcm-topics-codelab/starter/StockNewsServer/src/main/resources
. FcmSender.java
danFcmSubscriptionManager.java
memuat fileservice-account.json
dari classpath menggunakan kode berikut.
- Pada tahap ini, kode server sudah siap. Jalankan Build -> Build Project dari panel menu atas.
Mengirim Pesan Uji
- Di
FcmSender.java
, temukan fungsisendMessageToFcmRegistrationToken
dan masukkan token pendaftaran FCM yang Anda salin dari bagian Jalankan aplikasi awal ke kolomregistrationToken
. - Di fungsi
main
, hapus komentar hanya pada fungsisendMessageToFcmRegistrationToken
dan klik jalankan untuk mengeksekusi kode.- Amati bagaimana Token Pendaftaran FCM ditetapkan ke kolom
Token
dari objekmessage
. - Selain itu, perhatikan cara kita menggunakan
send
API dari antarmukaFirebaseMessaging
.
- Amati bagaimana Token Pendaftaran FCM ditetapkan ke kolom
- Tindakan ini akan mengirim pesan ke instance aplikasi yang telah Anda siapkan di langkah sebelumnya.
- Saat instance aplikasi berada di latar depan, Anda akan melihat konten pesan dalam log.
- Dan saat instance Aplikasi berada di latar belakang, Anda akan melihat pesan muncul di baki notifikasi.
Luar biasa, Anda telah menggunakan Firebase Admin SDK untuk mengirim pesan ke instance aplikasi. Baca selengkapnya tentang menggunakan Firebase Admin SDK di server Anda.
6. Mengimplementasikan Langganan/Penghentian Langganan Topik
Pada langkah ini, Anda akan menerapkan tindakan langganan dan pembatalan langganan topik, di tombol Kategori Saham Aplikasi Android.
Saat pengguna Aplikasi mengalihkan tombol untuk Kategori Saham tertentu, panggilan langganan atau pembatalan langganan topik akan dilakukan.
Meninjau kode
- Buka class
SubscriptionAdapter.java
di kode Aplikasi Android dan cari classRecyclerViewViewHolder
.
- Konstruktor class menyiapkan pemroses untuk tombol langganan menggunakan
setOnCheckedChangeListener
. - Bergantung pada tombol tombol, tindakan subscribe dan unsubscribe dilakukan dengan memanggil metode
subscribeToStockCategory
danunsubscribeFromStockCategory
. - Metode
setData
dipanggil olehonBindViewHolder
Adaptor RecyclerView untuk mengikat ViewHolder dengan Kategori Stok yang sesuai.
Menerapkan langganan topik
- Dalam metode
subscribeToStockCategory
, Anda akan menerapkan panggilan ke APIsubscribeToTopic
dari objekFirebaseMessaging
. 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 penghentian langganan topik
- Demikian pula, dalam kondisi else, Anda akan mengimplementasikan panggilan ke
unsubscribeFromTopic
API. Sesuatu berada di sepanjang baris berikut:
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
- Jalankan Aplikasi dan alihkan opsi Kategori Stok untuk menjalankan tindakan Berlangganan dan Berhenti Berlangganan. Token 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.
Mengimplementasikan integrasi sisi server untuk mengirim pesan topik
- Di kode server, buka
FcmSender.java
dan temukan metode bernamasendMessageToFcmTopic
.
- Di baris pertama, berikan Topik FCM yang ingin Anda kirimi pesan.
- Ini adalah string dalam bentuk:
/topics/<Topic Name>
. Contoh,/topics/Technology
.
- Ini adalah string dalam bentuk:
- Pada baris berikutnya, buat objek
message
baru (mirip dengan yang ditentukan dalam fungsisendMessageToFcmRegistrationToken
).- Perbedaannya adalah, bukan menetapkan kolom
Token
dari objekmessage
, tetapi Anda akan menetapkan kolomTopic
.
- Perbedaannya adalah, bukan menetapkan kolom
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();
- Sekarang tambahkan panggilan ke instance
FirebaseMessaging
untuk mengirim pesan (identik dengan panggilan pengiriman yang dilakukan dalam fungsisendMessageToFcmRegistrationToken
).
FirebaseMessaging.getInstance().send(message);
- Terakhir, update fungsi
main
dan aktifkan panggilan hanya ke fungsisendMessageToFcmTopic
.
Mengirim pesan dan memvalidasi tanda terima
- Sebelum mengirim pesan topik, pastikan terlebih dahulu bahwa instance aplikasi Anda berlangganan topik yang ingin Anda kirim.
- Tindakan ini dapat dilakukan dengan membalik tombol yang sesuai. Contoh:
- Sekarang Anda dapat mengirim pesan topik dengan menjalankan fungsi
main
dariFcmSender.java
. - Seperti sebelumnya, Anda akan dapat mengamati tanda terima pesan di instance aplikasi.
- Instance aplikasi di latar depan
- Instance aplikasi di latar belakang
- Bonus: Coba berhenti berlangganan topik yang Anda kirim dan kirim ulang pesan. Anda akan mengamati 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, pertimbangkan kemungkinan mengirim pesan ke grup instance aplikasi yang berlangganan topik Teknologi atau Otomotif. Kasus semacam itu dapat terjadi, misalnya, jika ada peristiwa penting yang melibatkan Waymo.
Topics memungkinkan Anda untuk mengekspresikan kombinasi dalam bentuk ekspresi boolean menggunakan operator berikut
- && : Logika AND. Misalnya,
'Technology' in topics && 'Automotive' in topics
- Hanya menargetkan instance aplikasi yang berlangganan Topics Teknologi dan Otomotif. - || : Logika ATAU. 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 Teknologi dan Otomotif atau Energi.
Baca selengkapnya tentang cara membuat permintaan kirim untuk menggunakan fungsi ini.
Menerapkan integrasi sisi server untuk mengirim pesan kondisi topik
- Kembali ke kode server, buka
FcmSender.java
dan temukan metode bernamasendMessageToFcmTopicCondition
.
- Di baris pertama, untuk variabel
topicCondition
, berikan kondisi topik yang ingin Anda kirimi pesan. Anda dapat menyetelnya ke:'Technology' in topics && 'Automotive' in topics
. - Pada baris berikutnya, buat objek
message
baru (mirip dengan yang ditentukan dalam fungsisendMessageToFcmTopic
).- Perbedaannya adalah, bukan menetapkan kolom
Topic
untuk objek, Anda akan menetapkan kolomCondition
.
- Perbedaannya adalah, bukan menetapkan kolom
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();
- Sekarang tambahkan panggilan ke instance
FirebaseMessaging
untuk mengirim pesan (sama dengan panggilan kirim yang dilakukan dalam fungsisendMessageToFcmTopic
).
FirebaseMessaging.getInstance().send(message);
- Terakhir, update fungsi
main
dan aktifkan panggilan hanya ke fungsisendMessageToFcmTopicCondition
.
Mengirim pesan dan memvalidasi tanda terima
- Sebelum mengirim pesan topik, pastikan terlebih dahulu bahwa instance aplikasi Anda memenuhi kondisi topik yang ditentukan dengan membuat instance aplikasi berlangganan topik Teknologi dan Otomotif.
- Sekarang Anda dapat mengirim pesan topik dengan menjalankan fungsi
main
dariFcmSender.java
. - Seperti sebelumnya, Anda akan dapat mengamati tanda terima pesan di instance aplikasi.
- Instance aplikasi di latar depan
- Instance aplikasi di latar belakang
- Bonus: Anda kini dapat berhenti berlangganan topik Teknologi dan mengirim ulang pesan kondisi topik. Anda akan mengamati bahwa pesan tidak diterima oleh instance aplikasi.
9. Rangkuman
Mari kita ulas secara ringkas apa yang telah Anda pelajari hingga saat ini.
- Cara memulai langganan topik / berhenti berlangganan dari instance aplikasi.
- Mengirim pesan ke topik dan memverifikasi tanda terima di instance aplikasi yang berlangganan.
- Mengirim pesan ke Kondisi topik dan memverifikasi tanda terima di instance aplikasi yang memenuhi kondisi.
Di bagian berikutnya, Anda akan mempelajari cara berlangganan/berhenti berlangganan instance aplikasi ke topik tanpa perlu membuat instance panggilan dari sisi klien.
10. Mengelola Langganan Topik dari Sisi Server
Hingga saat ini, dalam codelab ini, semua panggilan langganan topik dan pembatalan langganan dimulai dari instance aplikasi.
Namun, dalam beberapa kasus penggunaan, Anda mungkin ingin mengelola langganan topik dari Sisi Server. Misalnya, Anda mungkin ingin membuat subgrup basis pengguna yang ada berlangganan topik baru tanpa menunggu peluncuran aplikasi.
Di bagian ini, Anda akan mempelajari cara menggunakan Firebase Admin SDK untuk berlangganan dan berhenti berlangganan sekumpulan Token Pendaftaran FCM ke suatu topik dengan melakukan panggilan dari sisi server.
Menerapkan langganan Token Pendaftaran FCM sisi server ke topik FCM
- Di kode server, buka class
FcmSubscriptionManager.java
. Temukan metode bernamasubscribeFcmRegistrationTokensToTopic
. Anda akan mengimplementasikan panggilan kesubscribeToTopic
API di sini.
- Mari kita berlangganankan instance aplikasi ke topik Energi. Untuk melakukannya, pertama-tama berikan data untuk dua kolom berikut:
registrationTokens
: daftar string yang dipisahkan koma yang mewakili Token Pendaftaran FCM yang ingin Anda buat langganan topiknya.topicName
: nama topik untuk topik Energi, yaitu/topics/Energy
.
- Pada beberapa baris berikutnya, terapkan panggilan, seperti baris berikut:
TopicManagementResponse response = FirebaseMessaging.getInstance().subscribeToTopic( registrationTokens, topicName);
- Anda dapat memeriksa
TopicManagementResponse
untuk beberapa statistik hasil tingkat tinggi. Misalnya, mencetak jumlah langganan topik yang berhasil dibuat menggunakangetSuccessCount
.
System.out.printf("Num tokens successfully subscribed %d", response.getSuccessCount());
- Terakhir, dalam fungsi
main
, aktifkan panggilan hanya ke fungsisubscribeFcmRegistrationTokensToTopic
.
Membuat langganan dan mengirim pesan topik
- Pada tahap ini, Anda siap untuk membuat langganan topik dan mengirim pesan ke langganan topik tersebut.
- Jalankan fungsi
main
dari classFcmSubscriptionManager.java
. Tindakan ini akan membuat langganan topik. - Sekarang, siapkan kode untuk mengirim pesan. Serupa dengan sebelumnya,
- Di
FcmSender.java
, temukan fungsisendMessageToFcmTopic
. - Setel
topicName
ke topik Energy, yaitu,/topics/Energy
. - Buat objek
Message
dan targetkan ke topik menggunakansetTopic
. - Terakhir, perbarui metode
main
agar hanya mengaktifkan fungsisendMessageToFcmTopic
.
- Di
- Jalankan fungsi
main
dariFcmSender.java
. Tindakan ini akan mengirimkan pesan ke instance aplikasi dan Anda dapat mengamatinya di aplikasi seperti berikut.- Instance aplikasi di latar depan
- Instance aplikasi di latar belakang
Menerapkan penghentian langganan Token Pendaftaran FCM sisi server ke topik FCM
- Untuk membatalkan langganan topik sisi server, gunakan
unsubscribeFromTopic
API ini. Anda akan menambahkan kode yang relevan ke fungsiunsubscribeFcmRegistrationTokensFromTopic
dari classFcmSubscriptionManager.java
.
- Menerapkan kode berhenti berlangganan sisi server dan memvalidasi pengaruhnya dengan mengirim pesan topik, akan dibiarkan sebagai latihan untuk Anda.
11. Selamat
Selamat, Anda berhasil menggunakan topik FCM untuk mengirim pesan multicast ke subgrup instance aplikasi. Hal ini akan membantu menyederhanakan kemampuan Anda untuk menjangkau pengguna dengan konten yang relevan secara tepat waktu.
Apa langkah selanjutnya?
Setelah menyelesaikan codelab, pertimbangkan untuk mencoba topik untuk platform lain menggunakan panduan berikut: