Android厂商推送冲突了。。。

问题一

按照网易云信提供的 接入方法 需要接入小米的推送SDK,因为极光的已经引入,所以再次引入会冲突,这里就直接不引入,使用极光的就行,然后按照接入流程接入即可,在接入流程后面我们注意到AndroidManifest.xml文件中会插入如下内容:

<receiver

android:name=“com.netease.nimlib.mixpush.mi.MiPushReceiver”

android:exported=“true”>

 //这里设置了优先级

这个MiPushReceiver我们查看源码会发现它主要是处理并转发小米厂商推送的各种事件,MiPushReceiver同样是继承自小米push sdk中的PushMessageReceiver,MiPushReceiver代码如下:

到这里官方文档说已经可以开始测试推送消息,于是把手机进程杀掉,给手机发送一条消息,确实能够收到。但进程杀掉后原本接收正常的极光推送,现在却收不到了,其他厂商机型有的能收到,但点击推送消息不能打开App,我们看下图来分析原因:

不管是极光的消息还是云信的消息,首先都会把消息推给小米的推送云服务,然后小米手机系统会和小米的推送云服务保持一个长链接MiPush SDK收到后,首先会找到继承了PushMessageReceiver 并且注册到Manifest的Receiver,并把消息传给这个Receiver因为极光和云信在Manifest中都注册了PushMessageReceiver,所以这个时候谁能收到就存在不确定性了。如果配置了priority 优先级,则优先级高的会收到。回到上面我们注意到网易云信的 MiPushReceiver设置了优先级,所以要解释为什么极光的消息就收不到呢,我赶紧查看了下打包后Manifest中极光的PluginXiaomiPlatformsReceiver 如下:

<receiver

android:name=“cn.jpush.android.service.PluginXiaomiPlatformsReceiver”

android:exported=“true”>

果真,极光并没有设置优先级,这就能解释为什么极光的推送在网易云信接入厂商推送后收不到了。由于不同的厂商接入厂商推送的方式不同,对于上述这种冲突的表现也不太一样,像小米手机云信的消息总是优先于极光的推送,oppo、vivo都会显示消息但点击通知栏消息无反应(消息没有传到对应的Receiver),而华为的部分手机则能正常区分。**总之两个Receiver同时去接收厂商的推送,会出现冲突的情况。**然后我们继续在网易云信和极光的集成文档中寻找解决这种冲突的方案,终于我们在网易云信的文档后面找到了,紧接着我们遇到了第二个问题。

问题二

网易云信的推送文档中提供了小米推送兼容性的处理方案,云信提供了一个MiPushMessageReceiver ,让其他接入了厂商推送并处理推送转发逻辑的Receiver继承这个MiPushMessageReceiver,然后在对应的回调方法中处理处理相应的逻辑,MiPushMessageReceiver如下:

public class MiPushMessageReceiver extends BroadcastReceiver{

@Override

public final void onReceive(Context context, Intent intent) {}

public void onReceivePassThroughMessage(Context context, MiPushMessage message) {}

public void onNotificationMessageClicked(Context context, MiPushMessage message) {}

public void onNotificationMessageArrived(Context context, MiPushMessage message) {}

public void onReceiveRegisterResult(Context context, MiPushCommandMessage message) {}

public void onCommandResult(Context context, MiPushCommandMessage message) {}

}

然后将自己的Receiver添加到Manifest中,不去设置priority优先级:

这样就能保证推送都由网易云信的MiPushReceiver先接收到,然后通过判断是否是自己的推送消息,是自己的就直接处理,不是自己的就交给继承自MiPushMessageReceiver的Receiver处理,查看网易云信的源码发现确实是这样:

public final class MiPushReceiver extends PushMessageReceiver {

public MiPushReceiver() {}

public final void onNotificationMessageClicked(Context var1, MiPushMessage var2) {

if (g.a(var2.getExtra())) {

c.a(5).onNotificationClick(var1, var2); //自己处理

} else {

MiPushMessageReceiver var3;

if ((var3 = a.a(var1)) != null) {

var3.onNotificationMessageClicked(var1, var2);//交给MiPushMessageReceiver处理

}

}

}

}

如果按照云信推荐的方法,处理之后就是这样的流程:

好了到这里处理方式和原理都弄清楚了,我们现在也就只需要将极光处理推送的PluginXiaomiPlatformsReceiver改为继承MiPushMessageReceiver,然后按照上面的方法将其添加到Manifest中即可,看起来很简单,然后我们再来看看极光的PluginXiaomiPlatformsReceiver:

呃… 那么问题来了,这个类是包在极光推送的arr中的,**怎么去修改打好的arr包中类的继承呢?**这个问题似乎不太好解决啊~

##   解决问题

寻求云信和极光的帮助

首先想到的是这种处理同时监听厂商推送冲突的方案是云信提供的,那就先问问云信的技术有没有解决方案,云信给出的答复如下:

云信的意思是,他们只提供这种继承的兼容方案,如果是第三方封装了,他们也没太好的办法,然后推荐我们去找极光技术人员,商量把对应的类拆出来,首先想到的是如果极光能提供源码,我们直接修改下继承关系就好了,于是就赶紧找了极光的技术进行了沟通:

极光的技术表示他们只提供统一封装的版本,同时也没有考虑和其他第三方同时接入SDK导致的冲突问题,并且建议我们只集成一家的厂商通道…好吧!云信的人让我们找极光商量处理,极光的不但没有提供方案,还让我们别集成多家的厂商通道。不集成肯定满足不了业务需要。不过同时也能理解,不同的第三方在考虑接入厂商通道的时候应该也都是以自身能实现厂商通道来优先考虑,是否会影响其他的第三方,其他第三方是如何实现的,怎么去兼容,他们也管不了那么多,不过像云信还提供了兼容方案的,确实算不错了!后面发现极光的SDK混淆过,所以不提供源码也挺正常。看来拿不到极光PluginXiaomiPlatformsReceiver 的源码,云信和极光两方都提供不了有力帮助,问题只能我们自己想办法解决了。

分析问题原理,找解决方案

  • 分析作用

回过头来再思考下PluginXiaomiPlatformsReceiver 类的作用,在极光的SDK中,这个类继承了小米官方的PushMessageReceiver ,然后在打包后被添加到了Manifest文件中,从而有了监听小米系统推送、并转发消息给极光的SDK进行处理的能力,同时PluginXiaomiPlatformsReceiver类在其他地方并没有被调用。

最后

答应大伙的备战金三银四,大厂面试真题来啦!

这份资料我从春招开始,就会将各博客、论坛。网站上等优质的Android开发中高级面试题收集起来,然后全网寻找最优的解答方案。每一道面试题都是百分百的大厂面经真题+最优解答。包知识脉络 + 诸多细节。
节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

《960全网最全Android开发笔记》

《379页Android开发面试宝典》

包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。

如何使用它?
1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数

《507页Android开发相关源码解析》

只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。

真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。

腾讯、字节跳动、阿里、百度等BAT大厂 2020-2021面试真题解析

资料收集不易,如果大家喜欢这篇文章,或者对你有帮助不妨多多点赞转发关注哦。文章会持续更新的。绝对干货!!!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

对你有帮助不妨多多点赞转发关注哦。文章会持续更新的。绝对干货!!!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值