以小米为例,我们看看极光引入的cn.jiguang.sdk.plugin:xiaomi:3.3.9 arr包是如何工作的:

可以看到极光提供的这个arr包中直接把小米官方提供的MiPush_SDK_Client_3_6_18.jar(处理小米厂商推送的SDK) 包了进来,同时提供了一个PluginXiaomiPlatformsReceiver类,让其继承自上述小米jar包中的PushMessageReceiver打包后PluginXiaomiPlatformsReceiver会被添加到Manifest文件,当系统收到推送后,会将消息转发到继承了PushMessageReceiver的类,所以PluginXiaomiPlatformsReceiver就会收到消息,并将消息传递给极光自己的SDK进行处理,后面的流程就和App在前台的推送流程一样了。简单总结下这个Plugin类:**Plugin类会被注册到Manifest从而接收系统消息,并在对应的回调方法中将消息转发给极光SDK处理。**在网易云信兼容厂商推送之前这一切工作的都很好,应用进程被杀后,push推送可正常收到,问题从云信消息推送兼容厂商推送开始:

问题一

按照网易云信提供的 接入方法 需要接入小米的推送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 的源码,云信和极光两方都提供不了有力帮助,问题只能我们自己想办法解决了。

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

第三方在考虑接入厂商通道的时候应该也都是以自身能实现厂商通道来优先考虑,是否会影响其他的第三方,其他第三方是如何实现的,怎么去兼容,他们也管不了那么多,不过像云信还提供了兼容方案的,确实算不错了!后面发现极光的SDK混淆过,所以不提供源码也挺正常。看来拿不到极光PluginXiaomiPlatformsReceiver 的源码,云信和极光两方都提供不了有力帮助,问题只能我们自己想办法解决了。

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

Android厂商推送冲突了。。,三级缓存对性能的影响相关推荐

  1. Android厂商推送冲突了。。(1),2021年Android面试心得

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

  2. Android厂商推送冲突了。。,kotlin语法

    dependencies { - implementation 'cn.jiguang.sdk:jpush:3.3.9' implementation 'cn.jiguang.sdk:jcore:2. ...

  3. Android厂商推送接入

    先到极光推送后台开通厂商推送功能(此功能需要收费,需要联系商务开通) 到各厂商开发者平台注册应用,然后对应开启推送功能,获取对应的key和secret 需要注意的是,有些厂商在申请推送功能时审核时间有 ...

  4. Android 手机厂商推送服务调研

    由于谷歌服务在国内不能用,Android 的推送真是一大痛点,但也推动了国内一批做第三方服务的厂商.第三方推送做的比较好的有极光.个推.百度.友盟,经过比较之后,最后选择了极光推送.其实这些第三方推送 ...

  5. Android 多厂商推送集成

    前言 按劳分配,多劳多做.好不容易集成完了个推的推送 SDK,美滋滋的准备划一会儿水,鸟哥吩咐为了保证应用杀死后也可以接收到推送,并且降低服务端的维护多渠道的开发成本,还得集成下个推的多厂商渠道.等等 ...

  6. Android 消息推送OnePush

    Android 消息推送 1.实现原理 1.消息推送的实质 实际上,是当服务器有新消息需推送给用户时,先发送给应用App,应用App再发送给用户 推送的消息一般是用户需要的或app希望用户知道的消息 ...

  7. 总结的太牛了,android实时推送!

    本文介绍在Android中实现推送方式的基础知识及相关解决方案.推送功能在手机开发中应用的场景是越来起来了,不说别的,就我们手机上的新闻客户端就时不j时的推送过来新的消息,很方便的阅读最新的新闻信息. ...

  8. android 统一推送平台,工信部实验室成立安卓统一推送联盟:推送服务将实现统一...

    据微信公众号" 泰尔终端实验室"7月19日消息,移动互联网时代,消息推送是移动应用(APP)的一项重要功能,目前中国安卓系统生态环境尚不成熟,设备碎片化现象严重,导致不同应用与操作 ...

  9. android极光推送原理,【揭秘】极光推送ios、Android消息推送达率的原理

    初接触极光推送的使用者,为了衡量消息推送的质量.经常会纠结到消息的"送达率"这个概念.那么究竟什么是消息送达率呢?或者如何正确理解消息的送达情况呢? 基本概念 先来看与消息送达相关 ...

最新文章

  1. SpringCloud 分布式事务解决方案
  2. React-状态提升
  3. Android:安卓APP启动过程简介
  4. mongodb导出查询结果
  5. 聊聊flink Table的ScalarFunction
  6. 2020年生活服务业新业态和新职业从业报告
  7. 【kafka】Apache Kafka 0.11版本新功能简介
  8. 情感分析[深度学习/机器学习]专业英语词汇分享
  9. 笔记7:winfrom的一些知识点(一)
  10. (转)区块链:CITA
  11. .NET 使用MD5加盐加密
  12. Layui的下拉框样式失效问题
  13. (一)C++11 原生标准多线程:认识多线程
  14. Association Class VS Full Class
  15. FPGA 十进制 转化为二进制
  16. 用php获取本机的IP
  17. 票务系统的主要售票方式
  18. ESP8266 下载报错please check partition type 6 addr:3fd000 len:3000
  19. ipxe无盘服务器,iPXE-UEFI网启小工具
  20. 计算机清理垃圾文件丢失怎么恢复,垃圾箱清空了怎么恢复

热门文章

  1. Rufus 中文绿色版 - 简单快速制作 USB 启动盘软件 (U盘安装 Windows / Linux 系统)
  2. java linearlayout_Java LinearLayout.setMinimumHeight方法代码示例
  3. linux基本命令练习
  4. [nlp] 对抗学习 FGM, PGD到FreeLB
  5. vs2017 资源试图加载失败
  6. 【学习笔记】线性递推数列
  7. Maven仓库的布局、分类
  8. python手机题库app_Python基础_学习通app_期末答案
  9. python开发项目:学生选课系统
  10. 《机械制造业智能工厂规划设计》——3.2 机械制造业智能工厂参考模型