【发布时间】:2014-04-20 20:27:17
【问题描述】:
我正在制作自己的 Android 应用程序,并在此过程中发现了 GCM(Google Cloud Messaging)。我完全按照以下教程进行操作:http://javapapers.com/android/google-cloud-messaging-gcm-for-android-and-push-notifications/
好消息是几乎一切正常,除了每次我发送推送通知时,App force 在设备上关闭。我认为 Eclipse 项目没有任何问题,我在我的设备上运行 Android 4.2.2。没有编译错误。我不知道为什么应用程序一直强制关闭,这让我抓狂。
代码与上面链接中列出的代码完全相同。作为参考,这是我的 logcat:
E/AndroidRuntime( 7261): FATAL EXCEPTION: main
E/AndroidRuntime( 7261): java.lang.RuntimeException: Unable to instantiate receiver com.javapapers.android.GcmBroadcastReceiver: java.lang.ClassNotFoundException: Didn't find class "com.javapapers.android.GcmBroadcastReceiver" on path: /data/app/com.javapapers.android-1.apk
E/AndroidRuntime( 7261): at android.app.ActivityThread.handleReceiver(ActivityThread.java:2428)
E/AndroidRuntime( 7261): at android.app.ActivityThread.access$1600(ActivityThread.java:151)
E/AndroidRuntime( 7261): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1358)
E/AndroidRuntime( 7261): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime( 7261): at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime( 7261): at android.app.ActivityThread.main(ActivityThread.java:5285)
E/AndroidRuntime( 7261): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 7261): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime( 7261): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
E/AndroidRuntime( 7261): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
E/AndroidRuntime( 7261): at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:126)
E/AndroidRuntime( 7261): at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime( 7261): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.javapapers.android.GcmBroadcastReceiver" on path: /data/app/com.javapapers.android-1.apk
E/AndroidRuntime( 7261): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:65)
E/AndroidRuntime( 7261): at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
E/AndroidRuntime( 7261): at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
E/AndroidRuntime( 7261): at android.app.ActivityThread.handleReceiver(ActivityThread.java:2423)
E/AndroidRuntime( 7261): ... 11 more
W/GTalkService( 1430): [DataMsgMgr] broadcast intent callback: result=CANCELLED forIntent { act=com.google.android.c2dm.intent.RECEIVE pkg=com.javapapers.android (has extras) }
我的清单如下所示:
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<permission
android:name="com.javapapers.android.permission.C2D_MESSAGE"
android:protectionLevel="signature" />
<uses-permission android:name="com.javapapers.android.permission.C2D_MESSAGE" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-sdk
android:minSdkVersion="9"
android:targetSdkVersion="16" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:name=".RegisterActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name="com.javapapers.android.MainActivity"
android:configChanges="orientation|keyboardHidden"
android:label="@string/app_name" >
</activity>
<receiver
android:name=".GcmBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND" >
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
<category android:name="com.javapapers.android" />
</intent-filter>
</receiver>
<service android:name=".GCMNotificationIntentService" />
我正在竭尽全力试图找出问题所在,因此感谢您提供任何和所有帮助。
【问题讨论】:
-
供将来参考:不要在 pastebin 链接中发布近 7000 行 logcat。我已经将相关部分编辑到您的问题中。问题很可能是您没有在清单中声明
BroadcastReceiver。 -
对不起,不完全确定什么是相关的(所以发布了所有内容),我会记住它以备将来使用。至于声明它,我用清单文件更新了 OP。它被声明为“.GcmBroadcastReceiver”
标签: android google-cloud-messaging