android - 收到新的FCM消息(前景和背景)时,Android应用程序崩溃

标签 android kotlin push-notification google-cloud-messaging firebase-cloud-messaging

我正在我的应用程序中实施FCM。
我正在按照文档中的指南进行操作,并尝试按照文档中的建议实施简单的测试,但是每当我从控制台发送通知时,应用都会崩溃,无论它处于前台还是后台。

**更新:我已经删除了服务类,gradle中的减速度和实现。如果我尝试测试消息,该应用程序仍然崩溃。它不应该完全不受它影响吗?

这是我的延伸类(class):

import android.util.Log
import com.google.firebase.auth.FirebaseAuth
import com.google.firebase.database.FirebaseDatabase
import com.google.firebase.iid.FirebaseInstanceId
import com.google.firebase.messaging.FirebaseMessagingService
import com.google.firebase.messaging.RemoteMessage

class MyFirebaseMessagingService : FirebaseMessagingService() {

    override fun onMessageReceived(p0: RemoteMessage?) {
        super.onMessageReceived(p0)

        Log.d("newMessage", p0!!.notification!!.body)
    }

    override fun onNewToken(p0: String?) {
        super.onNewToken(p0)
        FirebaseInstanceId.getInstance().instanceId.addOnSuccessListener { idResult ->
            val uid = FirebaseAuth.getInstance().uid ?: ""

            val token = idResult.token

            val userRef = FirebaseDatabase.getInstance().getReference("/users/$uid/services/firebase-token")
            userRef.setValue(token)
        }
    }
}

这是我的 list :
    <service
            android:name=".otherClasses.MyFirebaseMessagingService"
            android:exported="false">
        <intent-filter>
            <action android:name="com.google.firebase.MESSAGING_EVENT" />
        </intent-filter>
    </service>

这是崩溃日志:
2019-04-18 11:45:44.007 21257-21295/co.getdere E/AndroidRuntime: FATAL EXCEPTION: Firebase-WrappedFirebaseMessagingService
    Process: co.getdere, PID: 21257
    java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Context.getPackageName()' on a null object reference
        at android.content.ContextWrapper.getPackageName(ContextWrapper.java:135)
        at com.google.firebase.messaging.zzb.<init>(Unknown Source:5)
        at com.google.firebase.messaging.FirebaseMessagingService.zzd(Unknown Source:58)
        at com.google.firebase.iid.zzb.run(Unknown Source:2)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
        at com.google.android.gms.common.util.concurrent.zza.run(Unknown Source:6)
        at java.lang.Thread.run(Thread.java:764)

最佳答案

像这样尝试。可能有效

class MyFirebaseMessagingService : FirebaseMessagingService() {
    companion object {

        private val TAG = "MyFirebaseMsgService"
    }

    override fun onNewToken(s: String?) {
        super.onNewToken(s)
        //        Displaying token on logcat
        Log.e(TAG, "Refreshed token: " + s!!)
    }

    override fun onMessageReceived(remoteMessage: RemoteMessage?) {
        Log.e(TAG, "onMessageReceived")
    }    
}

将其添加到 list 文件中
 <service
     android:name=".fcm.MyFirebaseMessagingService"
      android:exported="false">
      <intent-filter>
     <action android:name="com.google.firebase.MESSAGING_EVENT" />
      </intent-filter>
    </service>

关于android - 收到新的FCM消息(前景和背景)时,Android应用程序崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55738053/

相关文章:

android - 更新 Android 应用程序。小更新

kotlin - println() 产生不同的输出

generics - Kotlin 泛型

c# - 如何在 C# 中使用任何可靠的 XMPP 库连接 FCM 服务器?

android - AppWidgetManager getAppWidgetIds 返回旧的 Widget id

Android 应用程序在 HTC 和索尼爱立信手机上崩溃

android - ViewModelProviders 在 1.1.0 中已弃用

android - Kotlin - 将 List 转换为 MutableList 的最惯用方式

javascript - 推送通知的“showNotification”未定义

Android 推送通知限制 (C2DM)