错误:GCM中的java.io.IOException:SERVICE_NOT_AVAILABLE

时间:2014-12-01 12:43:58

标签: android google-cloud-messaging

我正在尝试将GCM集成到我的android项目中。我在Google API控制台上创建了项目,并为GC服务启用了GCM。

当我尝试注册它时,我得到异常java.io.IOException: SERVICE_NOT_AVAILABLE。我正在使用API​​控制台中项目编号正确的SENDER_ID。

任何人都可以帮助我解决这个问题的原因吗?

我的移动时间是正确的,以下是我在AndroidManifest.xml中添加的内容

Android.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.xyz"
    android:versionCode="1"
    android:versionName="1.0" >

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

    <uses-permission android:name="com.android.browser.permission.READ_HISTORY_BOOKMARKS" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.GET_ACCOUNTS" />
    <uses-permission android:name="android.permission.READ_CONTACTS" />
    <uses-permission android:name="android.permission.READ_CALL_LOG" />
    <uses-permission android:name="android.permission.READ_SMS" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.GET_TASKS" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.RECEIVE_SMS" />
    <uses-permission android:name="android.permission.READ_SMS" />

    <!-- This app has permission to register and receive data message. -->
    <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />

    <permission
        android:name="com.xyz.permission.C2D_MESSAGE"
        android:protectionLevel="signature" />

    <uses-permission android:name="com.xyz.permission.C2D_MESSAGE" />

    <application
        android:name="com.xyz.application.LaddooApplication"
        android:allowBackup="true">

        <receiver
            android:name="com.xyz.gcm.GcmBroadcastReceiver"
            android:permission="com.google.android.c2dm.permission.SEND" >
            <intent-filter>

                <!-- Receives the actual messages. -->
                <action android:name="com.google.android.c2dm.intent.RECEIVE" />

                <category android:name="com.xyz" />
            </intent-filter>
        </receiver>

        <meta-data
            android:name="com.google.android.gms.version"
            android:value="@integer/google_play_services_version" />

    </application>

</manifest>

代码

private void registerInBackground() {
    new AsyncTask<Void, Void, String>() {
        @Override
        protected String doInBackground(Void... params) {
            String msg = "";
            try {
                if (gcm == null) {
                    gcm = GoogleCloudMessaging.getInstance(context);
                }
                int retry = 0;
                while (retry < 5 && regid.length() == 0) {
                    regid = gcm.register(SENDER_ID);
                    ++retry;
                }

                msg = "Device registered, registration ID=" + regid;

                if (!regid.equals("")) {
                    // You should send the registration ID to your server
                    // over HTTP, so it
                    // can use GCM/HTTP or CCS to send messages to your app.
                    sendRegistrationIdToBackend();
                }
            } catch (IOException ex) {
                msg = "Error :" + ex.getMessage();
            }
            return msg;
        }

        @Override
        protected void onPostExecute(String msg) {
        }
    }.execute(null, null, null);
}

提前致谢。

3 个答案:

答案 0 :(得分:0)

好像您没有定义服务来处理GCM消息。有关详细信息,请查看this link。 它应该在您的清单中显示为:<service android:name="com.xyz.gcm.GcmIntentService" />

答案 1 :(得分:0)

当我调试我的GCM注册代码时,我发现Google Play服务很乐意经常收到这个电话。

如果您删除应用并尝试在全新安装后调用此方法,它始终有效。

我遵循了这里的指导方针,现在一切似乎都运转正常: https://developer.android.com/google/gcm/client.html

答案 2 :(得分:0)

如果您在模拟器中运行应用,则必须安装Google Play服务。

我最近从Google原生模拟器切换到GenyMotion Emulator并遇到此错误。后来我意识到GenyMotion图像没有附带Google Play服务。安装完成后,问题解决了。