Android融合推送MixPush SDK集成多家推送平台,共享系统级推送,杀死APP也能收到推送
消息推送是App运营的重要一环,为了优化消息推送成功率,降低电量和流量消耗,系统级的推送服务显得尤为重要。小米和魅族由此推出了自家的推送平台,在MIUI和Flyme上共享系统级推送服务,让APP在被杀死的情况下也能正常收到推送消息。以后也会有越来越多的手机厂商会推出自己的推送平台,MixPush由此而生,降低开发者集成多家推送的开发成本,提高推送的到达率。
项目开源Github
https://github.com/joyrun/MixPush
推荐推送平台
小米推送
支持所有的Android平台,特点是在MIUI系统上共享系统级推送,APP被杀死也可以收到通知栏推送。
https://dev.mi.com/console/appservice/push.html
魅族推送
仅仅支持Flyme系统,不能在非Flyme系统上使用,特点是在Flyme系统共享系统级推送,APP被杀死也可以收到通知栏推送。
https://open.flyme.cn/open-web/views/push.html
个推推送
Android平台上最大的第三方推送平台,推送消息稳定。
http://www.getui.com/cn/index.html
原理图
原理分析
MixPush只是一个降低集成多家推送服务的框架,自身不拥有推送功能,所有的推送功能都是依靠各个推送平台来实现。从原理图可以看到,客户端APP会根据不同的手机注册不同的推送平台,不能同时注册两个推送服务,避免重复收到推送。而服务端不用考虑需要推送消息的用户手机属于何种平台,一律向各个平台发起推送,而客户端会根据注册的平台只会收到单一平台的推送消息。
Android客户端配置
添加仓库地址,修改根目录的build.gradle文件:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
选择推送平台,如果没有可以参考源码自行实现,添加依赖:
dependencies {
compile 'com.github.joyrun.MixPush:client-core:1.0.0' //必填
compile 'com.github.joyrun.MixPush:client-mipush:1.0.0' // 小米推送
compile 'com.github.joyrun.MixPush:client-getui:1.0.0' // 个推
compile 'com.github.joyrun.MixPush:client-meizu:1.0.0' // 魅族推送,魅族推送只支持Flyme系统,务必需要注意
}
创建一个继承MixPushIntentService的服务类,用于接收事件:
public class PushIntentService extends MixPushIntentService {
@Override
public void onReceivePassThroughMessage(MixPushMessage message) {
Log.e(TAG, "收到透传消息 -> " + message.getContent());
}
@Override
public void onNotificationMessageClicked(MixPushMessage message) {
Log.e(TAG, "通知栏消息点击 -> " + message.getContent());
}
}
配置AndroidManifest.xml,注册服务类
<manifest>
<application ...>
...
<service android:name=".PushIntentService"/>
</application>
</manifest>
在Application类进行初始化,如果没有请自行创建:
public class DemoApplication extends Application {
public static final String MEIZU_APP_ID = "<MEIZU_APP_ID>";
public static final String MEIZU_APP_KEY = "<MEIZU_APP_KEY>";
public static final String MIPUSH_APP_ID = "<MIPUSH_APP_ID>";
public static final String MIPUSH_APP_KEY = "<MIPUSH_APP_KEY>";
@Override
public void onCreate() {
super.onCreate();
initPush();
}
private void initPush() {
MixPushClient.addPushManager(new MeizuPushManager(MEIZU_APP_KEY, MEIZU_APP_ID));
MixPushClient.addPushManager(new MiPushManager(MIPUSH_APP_ID, MIPUSH_APP_KEY));
MixPushClient.addPushManager(new GeTuiManager());
MixPushClient.setPushIntentService(PushIntentService.class);
MixPushClient.setSelector(new MixPushClient.Selector() {
@Override
public String select(Map<String, MixPushManager> pushAdapterMap, String brand) {
// return GeTuiManager.NAME;
//底层已经做了小米推送、魅族推送、个推判断,也可以按照自己的需求来选择推送
return super.select(pushAdapterMap, brand);
}
});
// 配置接收推送消息的服务类
MixPushClient.setPushIntentService(PushIntentService.class);
// 注册推送
MixPushClient.registerPush(this);
// 绑定别名,一般是填写用户的ID,便于定向推送
MixPushClient.setAlias(this, getUserId());
// 设置标签,用于对用户进行划分
MixPushClient.setTags(this,"广东");
}
private String getUserId(){
return "103";
}
}
修改APP的build.gradle文件,配置个推的APP ID等信息
android {
defaultConfig {
...
manifestPlaceholders = [
GETUI_APP_ID : "<GETUI_APP_ID>",
GETUI_APP_KEY : "<GETUI_APP_KEY>",
GETUI_APP_SECRET : "<GETUI_APP_SECRET>",
PACKAGE_NAME: "<APP的包名>"
]
}
}
定制通知栏通知的图标
小米推送
目前通知类的消息, 通知的图标展示规则如下:
- 如果app中同时存在名为mipush_notification和mipush_small_notification的drawable文件,则使用mipush_notification的drawable作为通知的大图标,mipush_small_notification的drawable作为通知的小图标。
- 如果app中只存在其中一个drawable文件,则使用该drawable作为通知的图标。
- 如果app中不存在这两个drawable文件,则使用app的icon作为通知的图标。在MIUI中,通知栏图标统一显示为app的icon,不可以定制。
个推推送
为了修改默认的通知栏顶部提示小图标,请在资源目录的res/drawable-ldpi/、res/drawable-mdpi/、res/drawable-hdpi/、res/drawable-xhdpi/、res/drawable-xxhdpi/等各分辨率目录下,放置相应尺寸的文件名为push.png
图片。
ldpi: 48*48
mdpi: 64*64
hdpi: 96*96
xhdpi: 128*128
xxhdpi: 192*192
魅族推送
和小米推送的一样。
注意
- 魅族推送只支持Flyme系统,务必需要注意。
服务端配置测试
目前只有Java的服务端代码,如果服务端使用其它语言,请参考设计思路自己开发。
复制代码和jar包到项目。
服务端推送测试
public class MixPushServerTest {
public static final String APP_PACKAGE_NAME = "<APP的包名>";
public static final String MIPUSH_APP_SECRET_KEY = "<MIPUSH_APP_SECRET_KEY>";
public static final Long MEIZU_APP_ID = <MEIZU_APP_ID>;
public static final String MEIZU_APP_SECRET_KEY = "<MEIZU_APP_SECRET_KEY>";
public static final String GETUI_APP_ID = "<GETUI_APP_ID>";
public static final String GETUI_APP_KEY = "<GETUI_APP_KEY>";
public static final String GETUI_MASTER_SECRET = "<GETUI_MASTER_SECRET>";
public static final String GETUI_URL = "http://sdk.open.api.igexin.com/apiex.htm";
static {
MixPushServer.addPushServerManager(new MiPushServerManager(APP_PACKAGE_NAME, MIPUSH_APP_SECRET_KEY));
MixPushServer.addPushServerManager(new MeizuPushServerManager(MEIZU_APP_ID, MEIZU_APP_SECRET_KEY));
MixPushServer.addPushServerManager(new GeTuiPushServerManager(GETUI_APP_ID, GETUI_APP_KEY, GETUI_MASTER_SECRET, GETUI_URL));
}
String title = "title";
String description = "description";
String json = "{\"name\":\"Wiki\",\"age\":24}";
@Test
public void sendNotifyToAll() throws Exception {
MixPushServer.sendNotifyToAll(title, description, json);
}
@Test
public void sendMessageToAll() throws Exception {
MixPushServer.sendMessageToAll(json);
}
@Test
public void sendMessageToAlias() throws Exception {
MixPushServer.sendMessageToAlias("100", json);
}
@Test
public void sendMessageToTags() throws Exception {
MixPushServer.sendMessageToTags("广东", json);
}
@Test
public void sendNotifyToAlias() throws Exception {
MixPushServer.sendNotifyToAlias("100", title, description, json);
}
@Test
public void sendNotifyToTags() throws Exception {
MixPushServer.sendNotifyToTags("广东", title, description, json);
}
}
如果你不是使用以上三个推送,也可以根据接口自己来实现。
Android融合推送MixPush SDK集成多家推送平台,共享系统级推送,杀死APP也能收到推送的更多相关文章
- Android消息推送 SDK 集成指南
使用提示 本文是 Android SDK 标准的集成指南文档. 匹配的 SDK 版本为:r1.8.0及以后版本. 本文随SDK压缩包分发.在你看到本文时,可能当前的版本与本文已经不是很适配.所以建议关 ...
- (转载)iOS 极光推送SDK 集成指南
iOS SDK 集成指南 使用提示 本文匹配的 SDK版本:r1.2.5 以后. 查看最近更新了解最新的SDK更新情况. 产品功能说明 极光推送(JPush)是一个端到端的推送服务,使得服务器端消息能 ...
- 极光推送>>java SDK服务端集成后台项目(使用详解)
PS:如果你是第一次用推送,那就直接按照我的步骤来,再去看官方文档,这样,更容易能理解操作流程.还有——-请耐心看 极光文档(java SDK)请参考 [ 极光文档 ] 步骤一: 首先,你必须在 [极 ...
- 手把手教你搞定个推iOS推送SDK集成
以下是一位开发者在集成个推iOS推送SDK过程中的真实经历. 作者:Ezreallp 一次偶然的机会,公司的项目要用到推送,我自己本来就很懒,不愿意去弄整套APNS的流程,刚好之前跟朋友聊起过他们的产 ...
- 极光推送 JPush 简介 集成 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- 极光推送iOS SDK教程
iOS SDK 调试指南 iOS 调试思维导图 2 确认证书 请到"应用详情页面"确认证书可用性: 3 开发环境测试 在对 JPush iOS 开发环境进行测试前,请确保 3 个 ...
- 李洪强iOS之集成极光推送三iOS集成指南
李洪强iOS之集成极光推送三iOS集成指南 SDK说明 适用版本 本文匹配的 SDK版本:r2.1.5 以后.查看最近更新了解最新的SDK更新情况.使用Xcode 6及以上版本可以使用新版Push S ...
- Kotlin与Android SDK 集成(KAD 05)
作者:Antonio Leiva 时间:Dec 19, 2016 原文链接:https://antonioleiva.com/kotlin-integrations-android-sdk/ 使用Ko ...
- 【笔记】android sdk集成的eclipse中导入项目
android sdk集成的eclipse中导入项目 想要把旧的ADT项目,一模一样的导入进来,需要: 1.把项目放到,非当前ADT的workspace目录下: 2.从Project中Import,选 ...
随机推荐
- mysql清除数据库中字符串空格方法
update `z_lottery_list` set `win_number`=replace(`win_number`,' ','');
- Linux下配置tomcat+apr+native应对高并发
摘要:在慢速网络上Tomcat线程数开到300以上的水平,不配APR,基本上300个线程狠快就会用满,以后的请求就只好等待.但是配上APR之后,Tomcat将以JNI的形式调用Apache HTTP服 ...
- 开始JAVA编程的敲门砖——JAVA开发环境搭建
从头开始的java编程--JAVA开发环境搭建 一.什么是java的开发环境? 顾名思义java的开发环境是提供并保证整个java程序开发运行的必要的环境,搭建java开发环境是开始java编程的敲门 ...
- 在线SVN仓库实现:金山快盘+TortoiseSVN(Win)+SCPlugin(Mac)
前段时间一直在研究SVN在线托管,也尝试了网上推荐的免费托管网站. 但毕竟是是免费的,还是要受到比如空间大小.私有性等这样那样的限制,感觉有些麻烦. 而且,比较心疼自己在本地开发的时候积累的更新日志, ...
- 工厂方法模式(Java与Kotlin版)
前文推送 设计模式 简单工厂模式(Java与Kotlin版) Kotlin基础知识 Kotlin入门第一课:从对比Java开始 Kotlin入门第二课:集合操作 Kotlin入门第三课:数据类型 初次 ...
- 关于jquery全选反选 批量删除的一点心得
废话不多说直接上代码: 下面是jsp页面的html代码: <table id="contentTable" class=""> <thead& ...
- 请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: Named Pipes Provider, error: 40 - 无法打开到 SQL Server 的连接)
程序异常,错误信息:在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务器.请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接. (pro ...
- 京东JOS API 接入使用笔记
商户开设了京东店.淘宝店,最近打算使用京东物流,需要使用京东仓库(京东店的订单使用京仓发货,淘宝等其他店使用京东云仓)发货,所以得从自家的ERP与京东沧海(ECLP)API对接,实现收发存. 首先得在 ...
- MySQL · 引擎特性 · InnoDB奔溃恢复
前言 数据库系统与文件系统最大的区别在于数据库能保证操作的原子性,一个操作要么不做要么都做,即使在数据库宕机的情况下,也不会出现操作一半的情况,这个就需要数据库的日志和一套完善的奔溃恢复机制来保证.本 ...
- CJOJ 2171 火车站开饭店(树型动态规划)
CJOJ 2171 火车站开饭店(树型动态规划) Description 政府邀请了你在火车站开饭店,但不允许同时在两个相连的火车站开.任意两个火车站有且只有一条路径,每个火车站最多有 50 个和它相 ...