Android融合推送MixPush SDK集成多家推送平臺,共享系統級推送,殺死APP也能收到推送

消息推送是App運營的重要一環,爲了優化消息推送成功率,下降電量和流量消耗,系統級的推送服務顯得尤其重要。小米和魅族由此推出了自家的推送平臺,在MIUI和Flyme上共享系統級推送服務,讓APP在被殺死的狀況下也能正常收到推送消息。之後也會有愈來愈多的手機廠商會推出本身的推送平臺,MixPush由此而生,下降開發者集成多家推送的開發成本,提升推送的到達率。html

項目開源Github

https://github.com/joyrun/MixPushandroid

推薦推送平臺

小米推送

支持全部的Android平臺,特色是在MIUI系統上共享系統級推送,APP被殺死也能夠收到通知欄推送。
https://dev.mi.com/console/appservice/push.htmlgit

魅族推送

僅僅支持Flyme系統,不能在非Flyme系統上使用,特色是在Flyme系統共享系統級推送,APP被殺死也能夠收到通知欄推送。
https://open.flyme.cn/open-web/views/push.htmlgithub

個推推送

Android平臺上最大的第三方推送平臺,推送消息穩定。
http://www.getui.com/cn/index.htmlweb

原理圖

image.png

原理分析

MixPush只是一個下降集成多家推送服務的框架,自身不擁有推送功能,全部的推送功能都是依靠各個推送平臺來實現。從原理圖能夠看到,客戶端APP會根據不一樣的手機註冊不一樣的推送平臺,不能同時註冊兩個推送服務,避免重複收到推送。而服務端不用考慮須要推送消息的用戶手機屬於何種平臺,一概向各個平臺發起推送,而客戶端會根據註冊的平臺只會收到單一平臺的推送消息。json

Android客戶端配置

添加倉庫地址,修改根目錄的build.gradle文件:api

allprojects {
        repositories {
            ...
            maven { url 'https://jitpack.io' }
        }
    }

選擇推送平臺,若是沒有能夠參考源碼自行實現,添加依賴:app

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,註冊服務類maven

<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的包名>"
        ]
    }
}

定製通知欄通知的圖標

小米推送

目前通知類的消息, 通知的圖標展現規則以下:

  1. 若是app中同時存在名爲mipush_notification和mipush_small_notification的drawable文件,則使用mipush_notification的drawable做爲通知的大圖標,mipush_small_notification的drawable做爲通知的小圖標。
  2. 若是app中只存在其中一個drawable文件,則使用該drawable做爲通知的圖標。
  3. 若是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
魅族推送

和小米推送的同樣。

注意

  1. 魅族推送只支持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);
    }
}

若是你不是使用以上三個推送,也能夠根據接口本身來實現。

相關文章
相關標籤/搜索