消息推送是App運營的重要一環,為了優化消息推送成功率,降低電量和流量消耗,系統級的推送服務顯得尤為重要。小米和魅族由此推出了自家的推送平臺,在MIUI和Flyme上共用系統級推送服務,讓APP在被殺死的情況下也能正常收到推送消息。以後也會有越來越多的手機廠商會推出自己的推送平臺,MixPush由此 ...
消息推送是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);
}
}
如果你不是使用以上三個推送,也可以根據介面自己來實現。