java - 安卓 GCM InstanceId.getToken() -> java.io.IOException : TIMEOUT

标签 java android google-cloud-messaging

我正在尝试在我的 Android 应用程序中实现推送通知,但我目前卡在了接收 token 的阶段。

我正在使用“InstanceID”的最新方法,并遵循了一些示例。 我已经将权限和服务添加到我的 list 中(并为它们添加了代码)但是无论我尝试什么,我总是得到“java.io.IOException:TIMEOUT”错误。我尝试了不同的手机、wifi、Lte 和 3G,但似乎没有任何改变。

我从未遇到过“SERVICE_NOT_AVAILABLE”错误。只停留在这一个。

list

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<receiver
  android:name="com.google.android.gms.gcm.GcmReceiver"
  android:exported="true"
  android:permission="com.google.android.c2dm.permission.SEND" >
  <intent-filter>
      <action android:name="com.google.android.c2dm.intent.RECEIVE" />
        <category android:name="de.company.appname" />
  </intent-filter>
</receiver>
<service
  android:name="de.company.gcm.ModuleGCMListenerService"
  android:exported="false" >
  <intent-filter>
     <action android:name="com.google.android.c2dm.intent.RECEIVE" />
  </intent-filter>
</service>
<service
  android:name="de.company.gcm.ModuleInstanceIDListenerService"
  android:exported="false">
  <intent-filter>
    <action android:name="com.google.android.gms.iid.InstanceID"/>
  </intent-filter>
</service>

InstanceID 调用:

try 
{
  token = instanceID.getToken(
            senderId,
            GoogleCloudMessaging.INSTANCE_ID_SCOPE, 
            null);
} 
catch (IOException e) 
{
  e.printStackTrace();
}

instanceID.getId() 正在运行。

W/InstanceID/Rpc: No response android.os.ConditionVariable@129d5713
W/System.err: java.io.IOException: TIMEOUT
W/System.err:   at com.google.android.gms.iid.zzc.zzb(Unknown Source)
W/System.err:   at com.google.android.gms.iid.zzc.zza(Unknown Source)
W/System.err:   at com.google.android.gms.iid.InstanceID.zzc(Unknown Source)
W/System.err:   at com.google.android.gms.iid.InstanceID.getToken(Unknown Source)

最佳答案

在代码中的相同位置搜索类似错误时,我终于弄清楚了我的问题。

New GCM API Register Unknown Source Error

在这种情况下,错误“MAIN_THREAD”确实更明显一些。

所以是因为InstanceId.getToken()不能在主线程中调用。

虽然它不适用于 new AsyncTask<Void, Void, Void>() Google Github 示例中建议的方法。

我不得不使用

new Thread(new Runnable() {
    public void run() {
        //code
    }
}).start();

关于java - 安卓 GCM InstanceId.getToken() -> java.io.IOException : TIMEOUT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33386593/

相关文章:

单击按钮后,Android 按钮文本变为垂直

android:configChanges 似乎被忽略了

android - 在 android 中缩放图像时图像质量差

android - 不使用 Firebase 的 GCM

java - 应用崩溃: How to delete a character in edittext by pressing delete button?

UserDaoImpl 处的 java.lang.ExceptionInInitializerError。<clinit>(UserDaoImpl.java :71)

java - Google App Engine Java 和 Android 入门

Azure 通知中心 : 'Test Send' was successfully sent,,但没有任何 GCM 流量。为什么?

java - 生成具有给定月份和年份的日历

java - 当连接多个设备时如何将 Appium 服务器保持为其分配的 AppiumDriver