Firebase云消息传递 -> Android中的非法状态异常

3
我是一个有用的助手,可以翻译文本。
我正在尝试基于 Cordova 制作一个应用程序,能够通过 FireBase 云消息传递发送通知。
这里是 MainActivity.java。
  public class MainActivity extends CordovaActivity
{

@Override
public void onCreate(Bundle savedInstanceState)
{
    Intent i=new Intent(this,NotificationService.class);
    startService(i);
    super.onCreate(savedInstanceState);
    // Set by <content src="index.html" /> in config.xml
    Helper mhelper=new Helper(this,appView);
        FirebaseMessaging.getInstance().subscribeToTopic("Testing");
        Log.d("Message","Subscribed To Testing");


    Log.d("Token",FirebaseInstanceId.getInstance().getToken());
    loadUrl(launchUrl);


}
}

然而,我在第49行遇到了非法状态异常:
    FirebaseMessaging.getInstance().subscribeToTopic("Testing");

其余的Manifest.xml等与此处提供的示例相同 https://github.com/firebase/quickstart-android/tree/master/messaging

在Logcat中,显示的错误是:

 FATAL EXCEPTION: main
                                                                   Process: careerage.jobseeker.app, PID: 5764
                                                                   java.lang.RuntimeException: Unable to start activity ComponentInfo{careerage.jobseeker.app/careerage.jobseeker.app.MainActivity}: java.lang.IllegalStateException: FirebaseApp with name [DEFAULT] doesn't exist. 
                                                                       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
                                                                       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
                                                                       at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:3738)
                                                                       at android.app.ActivityThread.access$900(ActivityThread.java:135)
                                                                       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1202)
                                                                       at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                       at android.os.Looper.loop(Looper.java:136)
                                                                       at android.app.ActivityThread.main(ActivityThread.java:5017)
                                                                       at java.lang.reflect.Method.invokeNative(Native Method)
                                                                       at java.lang.reflect.Method.invoke(Method.java:515)
                                                                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
                                                                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                                                                       at dalvik.system.NativeStart.main(Native Method)
                                                                    Caused by: java.lang.IllegalStateException: FirebaseApp with name [DEFAULT] doesn't exist. 
                                                                       at com.google.firebase.FirebaseApp.getInstance(Unknown Source)
                                                                       at com.google.firebase.FirebaseApp.getInstance(Unknown Source)
                                                                       at com.google.firebase.iid.FirebaseInstanceId.getInstance(Unknown Source)
                                                                       at com.google.firebase.messaging.FirebaseMessaging.getInstance(Unknown Source)
                                                                       at careerage.jobseeker.app.MainActivity$override.onCreate(MainActivity.java:49)
                                                                       at careerage.jobseeker.app.MainActivity$override.access$dispatch(MainActivity.java)
                                                                       at careerage.jobseeker.app.MainActivity.onCreate(MainActivity.java:0)
                                                                       at android.app.Activity.performCreate(Activity.java:5231)
                                                                       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
                                                                       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
                                                                       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245) 
                                                                       at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:3738) 
                                                                       at android.app.ActivityThread.access$900(ActivityThread.java:135) 
                                                                       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1202) 
                                                                       at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                       at android.os.Looper.loop(Looper.java:136) 
                                                                       at android.app.ActivityThread.main(ActivityThread.java:5017) 
                                                                       at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                       at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
                                                                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
                                                                       at dalvik.system.NativeStart.main(Native Method) 

我尝试过java.lang.IllegalStateException: FirebaseApp with name [DEFAULT],但它仍然无法识别FirebaseDatabase类。

https://dev59.com/jloU5IYBdhLWcg3wi3aX - USKMobility
@USKMobility 我也试过了。但我没有使用 Firebase 数据库。因此,在我的库中没有任何类存在。 - Yash Jain
我不是 Cordova 及其构建系统的专家,但 Firebase SDK 需要 gradle androidmanifest-merge 功能将额外的组件(在 Firebase 库中定义)添加到您的 androidmanifest.xml 文件中。 您能否检查您最终的 AndroidManifest 是否包含 Firebase 创建的内容提供程序? - Diego Giorgini
我想我弄清楚了。我认为 Fcm 和 Gcm 需要一些时间来获取令牌。如果我在分配令牌之前尝试使用云消息传递做任何事情,我将会收到错误提示。 - Yash Jain
2个回答

1
尝试将您的依赖项更新为:

compile 'com.google.firebase:firebase-messaging:9.0.2'

这个漏洞已在9.0.0和9.0.2之间的补丁中修复。


0

我认为 Fcm 和 Gcm 需要一些时间来获取令牌。如果您在分配令牌之前尝试使用云消息传递进行任何操作,您将会收到错误提示。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接