1

我正在使用这里描述的使用GoogleCloudMessaging类的新方法使用 gcm。但是 10 次中有 9 次给了我SERVICE_NOT_AVAILABLE错误。只有一次它注册了一个设备。

07-01 14:24:55.907    2074-2090/com.deveyes.carrefour          W/System.err:                   java.io.IOException: SERVICE_NOT_AVAILABLE

07-01 14:24:56.037    2074-2090/com.deveyes.carrefour          W/System.err: at com.google.android.gms.gcm.GoogleCloudMessaging.register(Unknown Source)

我的代码在我的活动中如下所示:

 .....
     gcmRegId = gcm.register(CarrefourConfig.GCM_SENDER_ID);   
 .....                                                       

后来我才知道我需要使用自动重试。我读过这个,但这个文件似乎很旧。与我们不再使用 IntentService 的新方式一样。还是我们?在 BroadcastReciever 中,我可以获取消息并通知用户。

我在这里做错了什么?

编辑:

我的清单:

<?xml version="1.0" encoding="utf-8"?>

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


<supports-screens
        android:xlargeScreens="false"
 />


<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

<uses-feature android:name="android.hardware.location" android:required="true" />
<uses-feature android:name="android.hardware.location.gps" android:required="false" />

<permission
        android:name="com.deveyes.carrefour.android.MAPS_RECEIVE"
        android:protectionLevel="signature" />


<uses-feature
        android:glEsVersion="0x00020000"
        android:required="true" />

<uses-permission android:name="com.deveyes.carrefour.android.permission.MAPS_RECEIVE" />
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />


<permission android:name="com.deveyes.carrefour.android.permission.C2D_MESSAGE"
            android:protectionLevel="signature" />
<uses-permission android:name="com.deveyes.carrefour.android.permission.C2D_MESSAGE" />

<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" />


<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/Theme.Carrefour"
        android:name=".CarrefourApplication">

    <meta-data
            android:name="com.google.android.maps.v2.API_KEY"
            android:value="AIzaSyCKznwauzk_rNdKf7Qw0rjpmf4AWchCRwI" />

    <activity
        android:name=".ui.MainActivity"
        android:label="@string/app_name"
        android:screenOrientation="portrait">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>


    <receiver
            android:name=".gcm.GCMBroadcastReceiver"
            android:permission="com.google.android.c2dm.permission.SEND" >
        <intent-filter>
            <action android:name="com.google.android.c2dm.intent.RECEIVE" />
            <category android:name="com.deveyes.carrefour" />
        </intent-filter>
    </receiver>

    <!--service android:name=".services.CarrefourLocationService" /-->


</application>

我的主要活动:

private void registerBackground() {

    new AsyncTask(){

        @Override
        protected Object doInBackground(Object[] objects) {

            try {
                if(gcm == null){
                    gcm = GoogleCloudMessaging.getInstance(context);
                }
                 gcmRegId = gcm.register(CarrefourConfig.GCM_SENDER_ID);

                Log.i(TAG,"regid:"+gcmRegId);

                setRegistrationId(context,gcmRegId);
                ServerUtilities.register(context,gcmRegId);


            } catch (IOException e) {
                e.printStackTrace();
            }
            return null;
        }
    }.execute(null,null,null);
}
4

3 回答 3

2

这是问题所在:

您应该在以下所有 3 个地方使用相同的包名称,但com.deveyes.carrefour.android在某些情况下和com.deveyes.carrefour其他情况下使用。

<permission android:name="com.deveyes.carrefour.android.permission.C2D_MESSAGE"
            android:protectionLevel="signature" />
<uses-permission android:name="com.deveyes.carrefour.android.permission.C2D_MESSAGE" />
...
    <receiver
            android:name=".gcm.GCMBroadcastReceiver"
            android:permission="com.google.android.c2dm.permission.SEND" >
        <intent-filter>
            <action android:name="com.google.android.c2dm.intent.RECEIVE" />
            <category android:name="com.deveyes.carrefour" />
        </intent-filter>
    </receiver>

如果您的包名称是com.deveyes.carrefour,请将清单更改为:

<permission android:name="com.deveyes.carrefour.permission.C2D_MESSAGE"
            android:protectionLevel="signature" />
<uses-permission android:name="com.deveyes.carrefour.permission.C2D_MESSAGE" />
...
    <receiver
            android:name=".gcm.GCMBroadcastReceiver"
            android:permission="com.google.android.c2dm.permission.SEND" >
        <intent-filter>
            <action android:name="com.google.android.c2dm.intent.RECEIVE" />
            <category android:name="com.deveyes.carrefour" />
        </intent-filter>
    </receiver>
于 2013-07-01T14:35:44.293 回答
1

嘿,在 GCM jar 中应该有一个名为 GCMRegistrar 的东西,您应该使用该方法注册到 GCM。以下是代码,试试看

GCMRegistrar.checkDevice(this);
 GCMRegistrar.checkManifest(this);
registerReceiver(mHandleMessageReceiver, new IntentFilter(
                DISPLAY_MESSAGE_ACTION));

        final String regId = GCMRegistrar.getRegistrationId(this);
        if (regId.equals("")) {
             GCMRegistrar.register(this, SENDER_ID); //this is where it registers
        } else {

            if (GCMRegistrar.isRegisteredOnServer(this)) {
                   Toast.makeText(getApplicationContext(), "Already registered with GCM", Toast.LENGTH_LONG).show();
            } 

我希望这个对你有用

于 2013-07-02T15:09:15.037 回答
0

我有同样的问题。

9/20 抛出 SERVICE_NOT_AVAILABLE 异常。显然这是谷歌方面的一个错误。适用于某些设备 (S3) 而不适用于其他设备 (LG L5)。

在这里检查。

我认为要做的事情是暂时使用旧 API,直到问题得到解决。

于 2013-08-25T16:52:36.273 回答