Java 注册推送通知期间Android崩溃
我正在使用gcm.jar进行推送通知。当我启动我的应用程序时,我试图注册推送通知,但它总是崩溃Java 注册推送通知期间Android崩溃,java,android,push-notification,android-c2dm,Java,Android,Push Notification,Android C2dm,我正在使用gcm.jar进行推送通知。当我启动我的应用程序时,我试图注册推送通知,但它总是崩溃 06-04 10:08:32.479: E/BroadcastReceiver(26774): BroadcastReceiver trying to return result during a non-ordered broadcast 06-04 10:08:32.479: E/BroadcastReceiver(26774): java.lang.RuntimeException: Broad
06-04 10:08:32.479: E/BroadcastReceiver(26774): BroadcastReceiver trying to return result during a non-ordered broadcast
06-04 10:08:32.479: E/BroadcastReceiver(26774): java.lang.RuntimeException: BroadcastReceiver trying to return result during a non-ordered broadcast
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.content.BroadcastReceiver.checkSynchronousHint(BroadcastReceiver.java:783)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.content.BroadcastReceiver.setResult(BroadcastReceiver.java:658)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at com.google.android.gcm.GCMBroadcastReceiver.onReceive(GCMBroadcastReceiver.java:56)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.app.ActivityThread.handleReceiver(ActivityThread.java:2394)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.app.ActivityThread.access$1500(ActivityThread.java:145)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1322)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.os.Handler.dispatchMessage(Handler.java:99)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.os.Looper.loop(Looper.java:137)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at android.app.ActivityThread.main(ActivityThread.java:5095)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at java.lang.reflect.Method.invokeNative(Native Method)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at java.lang.reflect.Method.invoke(Method.java:511)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:898)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
06-04 10:08:32.479: E/BroadcastReceiver(26774): at dalvik.system.NativeStart.main(Native Method)
我的Menifest.xml是
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<uses-permission android:name="com.app.example.permission.C2D_MESSAGE" />
<permission
android:name="com.app.example.permission.C2D_MESSAGE"
android:protectionLevel="signature" />
<receiver
android:name="com.google.android.gcm.GCMBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND" >
<intent-filter>
<!-- Receives the registration id. -->
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
<!-- Receives the actual messages. -->
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<category android:name="com.app.example" />
</intent-filter>
</receiver>
<service android:name="com.app.example.GCMIntentService" />
如何修复此崩溃?如果您有方法:
setResultCode()
,请删除它。我认为您正在获取和处理您的消息
@Override
protected void onMessage(Context context, Intent intent) {
handleMessage(context, intent);
}
当应用程序向谷歌发送注册设备的请求时,我不太清楚,但有时谷歌会返回消息,因此如果您正在解析消息并且意图不获取包,它会返回空,因此应用程序崩溃。
您可以尝试使用下面的代码,可能会有所帮助
@Override
protected void onMessage(Context context, Intent intent) {
//Bundle[{CMD=RST_FULL, from=google.com/iid}]
Bundle bundle = intent.getExtras();
if (bundle != null) {
if (!bundle.containsKey("CMD")) {
handleMessage(context, intent);
}
}
}
不,我没有方法:setResultCode()我也有同样的问题,没有setResultCode()。你能发布你的广播接收器代码吗?请在收到消息时调试并获取消息。
@Override
protected void onMessage(Context context, Intent intent) {
//Bundle[{CMD=RST_FULL, from=google.com/iid}]
Bundle bundle = intent.getExtras();
if (bundle != null) {
if (!bundle.containsKey("CMD")) {
handleMessage(context, intent);
}
}
}