記錄接入Firebase Cloud Messaging出現(xiàn)的一些問題

因為產(chǎn)品需要,接入Firebase Cloud Messaging實現(xiàn)消息通知垛叨,接入的時候踩了一些坑這里記錄一下伦糯。

  1. 最開始跟著Firebase教程在build.gradle引入

    implementation 'com.google.firebase:firebase-messaging:23.1.0'
    

    編譯報錯,引入的庫出現(xiàn)類沖突:

    Duplicate class com.google.firebase.iid.FirebaseInstanceIdReceiver found in modules jetified-firebase-iid-19.0.0-runtime (com.google.firebase:firebase-iid:19.0.0) and jetified-firebase-messaging-23.1.0-runtime (com.google.firebase:firebase-messaging:23.1.0)
    

    com.google.firebase:firebase-messaging:23.1.0和com.google.firebase:firebase-iid:19.0.0庫里面都有一個FirebaseInstanceIdReceiver類点额,但是繼承的基類不一致舔株,所以不能通過exclude group:移除。隨后嘗試降低版本到com.google.firebase:firebase-messaging:21.1.0还棱,編譯通過载慈。

  2. 然后更新com.google.firebase:firebase-analytics-ktx:21.0.0庫版本到21.2.0,編譯出現(xiàn)問題:

C:/Users/Admin/.gradle/caches/transforms-3/719f46791576794f028e9d76950ddae9/transformed/jetified-kotlin-stdlib-common-1.7.10.jar!/META-INF/kotlin-stdlib-common.kotlin_module: Module was compiled with an incompatible version of Kotlin. The binary version of its metadata is 1.7.1, expected version is 1.5.1.

經(jīng)過一番百度珍手,最后更新kotlin-gradle-plugin版本號為:1.6.0

classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.6.0"

編譯通過办铡。

  1. 隨后,測試的時候發(fā)現(xiàn)琳要,在Android 12出現(xiàn)了新的問題寡具,F(xiàn)irebase在控制臺發(fā)送測試設(shè)備的消息通知之后,點擊通知欄的消息無法進(jìn)入App稚补,很奇怪童叠。此時如果進(jìn)入App需要重新啟動,也就是該進(jìn)程被殺掉了课幕,猜測是點擊消息通知的時候出現(xiàn)了Crash厦坛。在Android 11以及以下是正常的,另外如果App切到后臺乍惊,然后等待接收到通知杜秸,此時切換到前臺,再下拉通知欄润绎,點擊該App的通知撬碟,那么可以正常從App啟動頁進(jìn)入。隨后調(diào)試發(fā)現(xiàn)莉撇,

    NotificationService: Indirect notification activity start (trampoline) from com.xxx.xxxx.xxx blocked
    

    經(jīng)過一番搜索之后發(fā)現(xiàn)呢蛤,從Android 12開始,禁用了點擊通知先打開Service/BroadCast棍郎,在從里面啟動Activity這種方式顾稀,必須是直接啟動Activity。猜測com.google.firebase:firebase-messaging:21.1.0版本就是用這種方式實現(xiàn)的消息通知坝撑。那么又只能回到問題1静秆,繼續(xù)解決問題1粮揉。

  2. 嘗試用其它方式引入firebase-messaging

    implementation platform('com.google.firebase:firebase-bom:31.1.0')
    implementation 'com.google.firebase:firebase-messaging'
    

    編譯依然是類沖突。最后嘗試指定com.google.firebase:firebase-iid:19.0.0的版本抚笔,引入最新版

    implementation 'com.google.firebase:firebase-iid:21.1.0'
    

    編譯通過扶认。

  3. 繼續(xù)發(fā)送測試消息通知,嘗試用Android 12機(jī)器從通知欄的消息點擊進(jìn)入殊橙,可以進(jìn)入App辐宾,達(dá)到預(yù)期效果,問題解決膨蛮。

常見問題

  • 按照教程接入Firebase Cloud Messaging了叠纹,但是無消息通知

    • 請檢查網(wǎng)絡(luò)是否能訪問外網(wǎng)
    • 檢查測試設(shè)備的FCM注冊令牌是否正確,App卸載重新安裝之后會更新令牌
    • 檢查機(jī)器是否有Google Play
  • App在前臺不能接收到消息提示

    沒有消息提示敞葛,但是會回調(diào)FirebaseMessagingService的onMessageReceived方法誉察,重寫自行實現(xiàn)通知即可。

    private void createNotification(RemoteMessage remoteMessage) {
        Intent intent = new Intent(this, NotificationActivity.class);
        intent.putExtra("text", remoteMessage.getData().get("message_data_text"));
        intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
    
        PendingIntent pendingIntent =  PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_ONE_SHOT);
        Uri defaultSoundUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
    
        NotificationCompat.Builder  notificationBuilder = new NotificationCompat.Builder(this, createChannel())
                .setSmallIcon(R.mipmap.ic_launcher)
               .setContentTitle(remoteMessage.getData().get("message_data_title"))
            .setContentText(remoteMessage.getData().get("message_data_text"))
                .setAutoCancel(true)
                .setSound(defaultSoundUri)
                .setContentIntent(pendingIntent);
    
        NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
        manager.notify(0, notificationBuilder.build());
    
    }
    
  • App殺掉進(jìn)程之后不能接收到通知

    檢查App是否有自啟動的權(quán)限惹谐,是否加入電池優(yōu)化了持偏。

  • 點擊消息通知進(jìn)入App的方式怎么拿到傳遞的參數(shù)?

    在啟動頁的onCreate從Intent中獲取氨肌,

    Intent intent = getIntent();
    if(intent.getExtras() != null && intent.getExtras().containsKey("key")) {
          String data = intent.getExtras().getString("key"));
    } 
    
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鸿秆,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子怎囚,更是在濱河造成了極大的恐慌卿叽,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件恳守,死亡現(xiàn)場離奇詭異附帽,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)井誉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來整胃,“玉大人颗圣,你說我怎么就攤上這事∑ㄊ梗” “怎么了在岂?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蛮寂。 經(jīng)常有香客問我蔽午,道長,這世上最難降的妖魔是什么酬蹋? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任及老,我火速辦了婚禮抽莱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘骄恶。我一直安慰自己食铐,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布僧鲁。 她就那樣靜靜地躺著虐呻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪寞秃。 梳的紋絲不亂的頭發(fā)上斟叼,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天,我揣著相機(jī)與錄音春寿,去河邊找鬼朗涩。 笑死,一個胖子當(dāng)著我的面吹牛堂淡,可吹牛的內(nèi)容都是我干的馋缅。 我是一名探鬼主播,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼绢淀,長吁一口氣:“原來是場噩夢啊……” “哼萤悴!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起皆的,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤覆履,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后费薄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體硝全,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年楞抡,在試婚紗的時候發(fā)現(xiàn)自己被綠了伟众。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡召廷,死狀恐怖凳厢,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情竞慢,我是刑警寧澤先紫,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站筹煮,受9級特大地震影響遮精,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜败潦,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一本冲、第九天 我趴在偏房一處隱蔽的房頂上張望准脂。 院中可真熱鬧,春花似錦眼俊、人聲如沸意狠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽环戈。三九已至,卻和暖如春澎灸,著一層夾襖步出監(jiān)牢的瞬間院塞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工性昭, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留拦止,地道東北人。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓糜颠,卻偏偏與公主長得像汹族,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子其兴,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,722評論 2 345