我的问题与stackoverflow的“doze-mode-and-gcm-notifications”和“android-doze-mode-gcm-priority”问题有关,但由于两者的解决方案是使用Google Play Service 8.3.0,所以对我的情况没有帮助。
我发送无声(不直接向用户显示)通过GCM向我的应用程序推送具有高优先级的通知。其中一些通知然后触发各种http请求以发送或从我的Web服务获取信息/文件。 由于我们需要能够随时执行这些操作,因此我们必须处理手机进入打盹模式的情况。
GCM通知正确唤醒了应用程序,但三星S6上的http请求失败(它们总是返回超时错误)。 cordova-plugin-network-information不提供插件脱机的信息。
在Nexus 5设备上进行的相同测试完全正常。
具有正常优先级的GCM通知由我的Samsung S6设备处理,处于IDLE状态。 (根据android doze documentation,在IDLE状态下,设备不会收到任何具有正常优先级的GCM通知,当设备切换到IDLE_MAINTENANCE状态时会处理这些通知。)
Nexus 5
两者都有开发人员选项和激活USB调试
我使用这些命令来激活打盹:
adb shell dumpsys battery unplug
adb shell dumpsys deviceidle force-idle
检查当前状态的命令:
adb shell dumpsys deviceidle | grep mState
切换状态的命令:
adb shell dumpsys deviceidle step
从那里我只使用Postman向gcm API请求以下数据:
POST https://android.googleapis.com/gcm/send
标题:
Authorization : key=<MYAPIKEY>
Content-Type : application/json
身体(RAW):
{
"data": {
"key": {"key":"value"},
"content-available": "1"
},
"registration_ids": ["<MYAPPTOKEN>"]
}
最后我的应用程序通过使用angular $ http方法或cordova-plugin-file-transfer来请求我的Web服务,如果我需要发送文件
有人遇到同样的问题,你找到了解决方案吗?
在这种特殊情况下,有人知道网络为什么不可用(或者它处于什么状态)? (同样,documentation说:“GCM高优先级消息可让您可靠地唤醒您的应用以访问网络”)
如果是这样,您是否也在其他设备型号上遇到问题?
奖金问题:有人知道三星设备在处于IDLE状态时处理普通优先级通知的原因吗? (我不知道我是否必须为这个问题创建一个单独的问题,因为它对我来说只是一个问题,但它可能以某种方式与主要问题相关联)
答案 0 :(得分:0)
我也遇到过网络GCM问题。我有一个像活动一样做IM的GCM服务。最近我发现在Android 7.0(三星Galaxy S6s和S8)上睡了10分钟后,我的GCM服务无法再连接到服务器了。它非常好奇,因为从文档中我们必须选择让应用程序受到Doze和App Standby的影响。
我确实找到了一个工作。如果您使用完全唤醒锁定,它可以实现网络连接。我意识到这是一种强力方法。但目前它是我能找到的唯一解决方案。这基本上就是我在做什么......
public class GcmIntentService extends IntentService {
….
protected void onMessage(Context context, Intent intent) {
PowerManager powerManager = (PowerManager) getApplicationContext().getSystemService(Context.POWER_SERVICE);
PowerManager.WakeLock wakeLock = powerManager.newWakeLock((PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP), "GCMOnMessage");
try {
logger.d("Processing incoming GCM message. Connecting test. ");
URL url = new URL("http://www.google.com/";;);
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
int status = urlConnection.getResponseCode();
logger.d("status: " + status);
}
catch (MalformedURLException e) {
e.printStackTrace();
}
finally {
logger.d("Releasing wake lock.");
wakeLock.release();
}
}
&#13;