前两个月接入了Android华为推送,遇到的坑真是不少,在此记录下。
坑1:有两个华为推送?我可能接入了假的华为推送
- 老的
PUSH服务
http://developer.huawei.com/push - 新的
HMS服务
中的PUSH服务 http://developer.huawei.com/consumer/cn/wiki/index.php?title=HMS%E5%BC%80%E5%8F%91%E6%8C%87%E5%AF%BC%E4%B9%A6-PUSH%E6%9C%8D%E5%8A%A1%E6%8E%A5%E5%8F%A3
一开始接入了老的PUSH SDK,然而后端的兄弟在接HMS,于是乎我又改回HMS了。。问了下客服,说推荐使用HMS的PUSH服务,再往下都是针对HMS的坑
。
至于什么是HMS,见华为官方文档http://developer.huawei.com/consumer/cn/wiki/index.php?title=HMS%E4%BB%8B%E7%BB%8D
坑2:初始化依赖Activity,所以不能在Application中进行初始化
不同于其他第三方推送直接注册初始化,因为多了HMS这一层,所以需要先初始化HMS服务,成功后才能注册PUSH服务。而初始化HMS是可能失败的!!!还好SDK也帮你考虑了,按照官方demo在onConnectionFailed和onActivityResult里处理即可:
@Override
public void onConnectionFailed(@NonNull ConnectionResult result) {
Log.i(TAG, "onConnectionFailed, ErrorCode: " + result.getErrorCode());
if (mResolvingError) {
return;
}
int errorCode = result.getErrorCode();
HuaweiApiAvailability availability = HuaweiApiAvailability.getInstance();
if (availability.isUserResolvableError(errorCode)) {
mResolvingError = true;
availability.resolveError(this, errorCode, REQUEST_RESOLVE_ERROR, this);
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
//华为推送
if (requestCode == REQUEST_RESOLVE_ERROR) {
Log.i(TAG, "onActivityResult, ResultCode: " + resultCode + ", Intent: " + data);
mResolvingError = false;
int result = HuaweiApiAvailability.getInstance().isHuaweiMobileServicesAvailable(this);
if (result == ConnectionResult.SUCCESS) {
if (!huaweiApiClient.isConnecting() && !huaweiApiClient.isConnected()) {
huaweiApiClient.connect();
}
} else {
// TODO: 处理errorCode
}
}
}
errorCode的具体含义参考下载下来的HMS SDK中的文档吧docs/API_Reference/constant-values.html。
这里涉及另一个坑
坑2.1:上面的resolveError不一定成功
比如我就遇到有用户反馈弹窗提示安装“华为移动服务”,然后安装不上。华为移动服务就是这个鬼东西http://a.vmall.com/app/C10132067 ,HMS依赖它。按理说华为手机应该自带,然而很多老手机没带或者版本太旧。OK,上面都resolveError弹框去下载安装了,然而这还是可能失败,需要在onUpdateFailed再手动处理
public void onUpdateFailed(@NonNull ConnectionResult result) {
Log.i(TAG, "onUpdateFailed, ErrorCode: " + result.getErrorCode());
mResolvingError = false;
if(result.getErrorCode()==ConnectionResult.INTERNAL_ERROR){
//更新失败,打开华为应用市场的"华为移动服务"app页面或者手动下载
downloadHMS();
}
}```
#####坑3:透传不靠谱就算了,通知栏消息也可能收不到
官方文档中说明:透传消息需要设置开机自启动才能拉起应用。
我手上有台华为P8移动4G标准版,通知栏消息死活是收不到的。
问了客服,给了以下说明:(我能怎么办,我也很绝望啊
```华为手机上:
Emui3.0上,Push广播有很大概率被限制,如: Mate7 3.0版本,荣耀6plus,P7 3.0版本,4X, 4A等。
Emui3.1上,Push广播基本不被限制,但个别型号机型存在问题,如:荣耀5x等。
Emui4.0及以上,Push广播有较高概率被限制,不被限制的机型如:荣耀畅玩4C,荣耀畅玩4X,Mate S,P8 MAX等。
如广播被限制,需要将应用设为开机启动项。所以对于及时性或到达率要求非常高的应用,我们建议应用要考虑替代方案。
后续Push版本,华为将采用新的设计方案,解决被限制的问题,但发布计划待定。
另外,至于限制的问题,其实华为sdk还是能接收到推送消息的,当将消息通过广播发送给应用是,如果手机管家查到该应用处于stop状态,那么会拦截该广播的。```
#####结束语
因为众所周知的原因,GCM想进来天朝太难了。现在华为联合阿里巴巴等几个大厂搞安卓绿色联盟,希望能彻底解决国产手机的推送问题吧。
#####其他参考
[android集成华为推送总结](http://www.jacpy.com/2017/01/20/huawei-push-summary.html)
[集成华为推送那些坑](http://www.jianshu.com/p/47a6826f9815)
[Android端外推送到底有多烦?](http://zhangtielei.com/posts/blog-android-push.html)
[Android集成华为推送的问题总结](http://www.qingpingshan.com/rjbc/az/260797.html)