三星S6上的打盹模式,GCM通知和http请求

时间:2016-06-17 15:57:08

标签: android cordova google-cloud-messaging samsung-mobile phonegap-pushplugin

我的问题与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状态时会处理这些通知。)

设备信息

  • 三星galaxy S6
  • Nexus 5

  • 两者都有开发人员选项和激活USB调试

  • 两台设备均使用wifi连接
  • 两台设备都以相同的方式安装应用程序:使用USB线连接到我的计算机,然后从Android Studio运行应用程序
  • 三星设备是全新的,只安装了基本应用程序。

申请信息

  • Cordova 6.1.1
  • Cordova phonegap-plugin-push 1.7.0
  • Angular 1.5.5 / ngCordova 0.1.26-alpha
  • Android Sdk Tools最新更新(Android支持存储库32除外,不要立即将其更新为33,因为它昨天才发布)

测试

我使用这些命令来激活打盹:

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状态时处理普通优先级通知的原因吗? (我不知道我是否必须为这个问题创建一个单独的问题,因为它对我来说只是一个问题,但它可能以某种方式与主要问题相关联)

1 个答案:

答案 0 :(得分:0)

我也遇到过网络GCM问题。我有一个像活动一样做IM的GCM服务。最近我发现在Android 7.0(三星Galaxy S6s和S8)上睡了10分钟后,我的GCM服务无法再连接到服务器了。它非常好奇,因为从文档中我们必须选择让应用程序受到Doze和App Standby的影响。

我确实找到了一个工作。如果您使用完全唤醒锁定,它可以实现网络连接。我意识到这是一种强力方法。但目前它是我能找到的唯一解决方案。这基本上就是我在做什么......

&#13;
&#13;
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;
&#13;
&#13;