2013-03-30 95 views
3

這似乎是一個相當普遍的問題沒有一個很好的答案。我只是跟着谷歌指南GCM推送消息,並正在此錯誤:C2D_MESSAGE權限錯誤?

E/AndroidRuntime(21779): java.lang.RuntimeException: Unable to start activity ComponentInfo{eric.bander.app/eric.bander.app.MenuScreen}: java.lang.IllegalStateException: Application does not define permission eric.bander.app.permission.C2D_MESSAGE 
E/AndroidRuntime(21779): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1968) 
E/AndroidRuntime(21779): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1993) 
E/AndroidRuntime(21779): at android.app.ActivityThread.access$600(ActivityThread.java:127) 
E/AndroidRuntime(21779): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1159) 
E/AndroidRuntime(21779): at android.os.Handler.dispatchMessage(Handler.java:99) 
E/AndroidRuntime(21779): at android.os.Looper.loop(Looper.java:137) 
E/AndroidRuntime(21779): at android.app.ActivityThread.main(ActivityThread.java:4507) 
E/AndroidRuntime(21779): at java.lang.reflect.Method.invokeNative(Native Method) 
E/AndroidRuntime(21779): at java.lang.reflect.Method.invoke(Method.java:511) 
E/AndroidRuntime(21779): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:978) 
E/AndroidRuntime(21779): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:745) 
E/AndroidRuntime(21779): at dalvik.system.NativeStart.main(Native Method) 
E/AndroidRuntime(21779): Caused by: java.lang.IllegalStateException: Application does not define permission eric.bander.app.permission.C2D_MESSAGE 
E/AndroidRuntime(21779): at com.google.android.gcm.GCMRegistrar.checkManifest(GCMRegistrar.java:137) 
E/AndroidRuntime(21779): at eric.bander.app.MenuScreen.onCreate(MenuScreen.java:43) 
E/AndroidRuntime(21779): at android.app.Activity.performCreate(Activity.java:4469) 
E/AndroidRuntime(21779): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1052) 
E/AndroidRuntime(21779): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1932) 

這裏是我的清單文件:

<uses-sdk 
    android:minSdkVersion="8" 
    android:targetSdkVersion="15" /> 

<uses-permission android:name="android.permission.INTERNET" /> 
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> 
<uses-permission android:name="android.permission.CONTROL_LOCATION_UPDATES" /> 
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> 
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> 
<uses-permission android:name="android.permission.GET_ACCOUNTS" /> 
<uses-permission android:name="android.permission.WAKE_LOCK" /> 

<permission android:name="eric.bander.app.permission.C2D_MESSAGE" android:protectionLevel="signature" /> 
<uses-permission android:name="eric.bander.app.permission.C2D_MESSAGE" /> 


    <receiver 
     android:name="com.google.android.gcm.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="eric.bander.app" /> 
     </intent-filter> 
    </receiver> 

這是的MainMenu的代碼段:

GCMRegistrar.checkDevice(this); 
GCMRegistrar.checkManifest(this); 
final String regId = GCMRegistrar.getRegistrationId(this); 
if (regId.equals("")) { 
    GCMRegistrar.register(this, "808426403545"); 
} else { 
    Toast.makeText(this, GCMRegistrar.getRegistrationId(this), Toast.LENGTH_LONG).show(); 
} 

我不知道它的相關,但我的應用程序strucutre是這樣的GCM inten在另一個包T服務:

eric.bander 
     -MainMenu.class 
eric.bander.misc 
     -GCMIntentService.class 

我希望有人能夠幫助這一點,總是令人沮喪,當你在下面的教程。

TIA

+1

我有同樣的問題,當我的GCM意圖類在另一個包。我只是將GCM意圖轉移到maniefest中使用的主包whateve包中,並且對我來說工作得很好。 –

+0

正是我所做的和它的工作。雖然我現在有一個不同的錯誤,說空的構造函數! –

+0

謝謝,它的全部工作。 –

回答

5

我的錯誤是其在不同的包GCMIntentService發送到註冊該GCM類。