java - Android 在注册推送通知期间崩溃

标签 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: 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" />

我的 BroadcastReciever 代码如下

public class GCMIntentService extends GCMBaseIntentService {

@SuppressWarnings("hiding")
private static final String TAG = "GCMIntentService ";

public GCMIntentService() {
    super(SENDER_ID);
}

@Override
protected void onRegistered(Context context, String registrationId) {
    PreferenceManager.getDefaultSharedPreferences(context).edit()
            .putString("REGISTRATION_KEY", registrationId).commit();
}

@Override
protected void onUnregistered(Context context, String registrationId) {
    // Debuger.e(TAG, "Device unregistered");
}

@Override
protected void onMessage(Context context, Intent intent) {
            handleMessage(context, intent);
}

@Override
protected void onDeletedMessages(Context context, int total) {
}

@Override
public void onError(Context context, String errorId) {
}

@Override
protected boolean onRecoverableError(Context context, String errorId) {
    // log message
    return super.onRecoverableError(context, errorId);
}

private void handleMessage(Context context, Intent intent) {
    // Do whatever you want with the message
    String order_ID = intent.getStringExtra("order_id");
    String status_ID = intent.getStringExtra("status_id");
    String message = intent.getStringExtra("message");

    if (!message.equals("")) {
        if (order_ID != null && status_ID != null & !status_ID.equals("4")) {
            Bundle bundle = new Bundle();
            bundle.putInt("fromGetItem", 2);
            mainIntent = new Intent(context.getApplicationContext(),
                    MainActivity.class);
            mainIntent.putExtras(bundle);
            mainIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            context.startActivity(mainIntent);
        }
        generateNotification(context, message, mainIntent);
    } 
}

private static void generateNotification(Context context, String message,
        Intent notificationIntent) {
    int icon = R.drawable.ic_launcher;
    long when = System.currentTimeMillis();
    NotificationManager notificationManager = (NotificationManager) context
            .getSystemService(Context.NOTIFICATION_SERVICE);
    Notification notification = new Notification(icon, message, when);

    String title = context.getString(R.string.app_name);

    PendingIntent intent = PendingIntent.getActivity(context, 0,
            notificationIntent, 0);
    notification.setLatestEventInfo(context, title, message, intent);
    notification.flags |= Notification.FLAG_AUTO_CANCEL;

    // Play default notification sound
    notification.defaults |= Notification.DEFAULT_SOUND;

    // Vibrate if vibrate is enabled
    notification.defaults |= Notification.DEFAULT_VIBRATE;
    notificationManager.notify(0, notification);
}
}

如何修复此崩溃?

最佳答案

我认为您正在接收和处理您的消息

@Override
protected void onMessage(Context context, Intent intent) {
        handleMessage(context, intent);
}

当 App 向 google 发送设备注册请求时,我不太清楚,但有时 google 会返回消息,因此如果您正在解析消息并且 Intent 没有得到你的 Bundle,它返回 null 所以 App 崩溃了。 您可以尝试使用以下代码,可能会有帮助。

@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);
        }
    }
}

关于java - Android 在注册推送通知期间崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30635507/

相关文章:

安卓工作室 : eglSurfaceAttrib not implemented

android - 在商店发布新版本的 Android 应用程序时更新 SQLite 数据库

swift - 如何安排进入某个区域后的某个时间推送通知? swift

iphone - 哪种方法用于注册推送通知的设备 token ?

ios - 推送通知 - 不同用户的不同角标(Badge)编号

java - JBoss 6 从 WEB-INF/lib of war 解压 jar

java - 如何知道一个列表有一个特定的索引?

android - FloatingActionButton 应该在不滚动的情况下可见(在 CollapsingToolbarlayout 中)

java - Guava 中的 Floats.tryParse()

javascript - 如何运行(或构建然后运行?)这个 Mozilla Rhino 调试器?