小米應(yīng)用商店:Android版快速接入指南

來源: 小米開放平臺(tái)
作者:小米開放平臺(tái)
時(shí)間:2020-09-27
17960
本文介紹小米應(yīng)用商店中關(guān)于Android版快速接入指南。

1.客戶端接入小米推送前的準(zhǔn)備工作

1.在小米開發(fā)者站開通小米開發(fā)者賬號(hào)。

2.創(chuàng)建應(yīng)用,開發(fā)者賬號(hào)審核通過后你就可以在開發(fā)者站創(chuàng)建你的應(yīng)用。

3.開啟應(yīng)用的推送服務(wù)。

4.下載SDK、文檔和DEMO。

2.Demo的使用

Android Demo提供了一些基本功能,比如注冊(cè)小米推送服務(wù)、設(shè)置別名、取消別名、訂閱標(biāo)簽、取消標(biāo)簽、設(shè)置消息的接收時(shí)間段等等。Demo的主Activity包含兩個(gè)部分:基本操作的Button和顯示這些操作結(jié)果信息(成功或失?。㏕extView。通過修改Anroid Demo中部分代碼,可以使在開發(fā)者站創(chuàng)建的應(yīng)用快速的接入小米推送服務(wù)。

1.將DemoApplication.java中APP_ID、APP_KEY值替換為應(yīng)用的對(duì)應(yīng)值,TAG替換為應(yīng)用的包名

1.jpg

2.將AndroidManifest.xml中package和permission包名替換為應(yīng)用的包名。

2.jpg

3.如果使用的IDE是Android Studio,還需要修改gradle配置

3.png

修改了以上幾處的代碼,可以在模擬器或者手機(jī)上安裝此應(yīng)用。Demo啟動(dòng)后,主界面上顯示了"Register push success."表示注冊(cè)小米推送服務(wù)成功,這時(shí)可以設(shè)置別名、訂閱標(biāo)簽。開發(fā)者可以利用小米網(wǎng)頁推送工具向?qū)?yīng)的別名或標(biāo)簽推送消息。為了能夠看到更詳細(xì)的log信息,可以在命令行下輸入:adb logcat|grep應(yīng)用包名

3.推送對(duì)象的選擇

推送對(duì)象目前支持四種:RegID、別名、userAccount、標(biāo)簽。

1.RegID:針對(duì)單一設(shè)備推送消息。應(yīng)用調(diào)用MiPushClient類的靜態(tài)方法registerPush注冊(cè)小米推送服務(wù),注冊(cè)的結(jié)果將通過PushMessageReceiver繼承類的onCommandResult方法和onReceiveRegisterResult中的MiPushCommandMessage參數(shù)對(duì)象message傳到客戶端。當(dāng)message對(duì)象的command等于MiPushClient.COMMAND_REGISTER并且message對(duì)象的resultCode等于ErrorCode.SUCCESS時(shí),message對(duì)象commandArguments包含了服務(wù)器返回的RegID??蛻舳说年P(guān)鍵代碼如下:

public void onCommandResult(Context context, MiPushCommandMessage message) {

        String command = message.getCommand();

        List<String> arguments = message.getCommandArguments();

        if (MiPushClient.COMMAND_REGISTER.equals(command)) {

            if (message.getResultCode() == ErrorCode.SUCCESS) {

              mRegID = arguments.get(0);

        }

}

2.RegID是由服務(wù)器端生成的,能夠唯一標(biāo)識(shí)某臺(tái)手機(jī)上的某個(gè)應(yīng)用。應(yīng)用在獲取到RegID后,需要將RegID上報(bào)到應(yīng)用的服務(wù)器,此時(shí)應(yīng)用服務(wù)端就可以利用RegID向客戶端發(fā)送消息。

別名:針對(duì)單一設(shè)備推送消息。應(yīng)用只有在成功注冊(cè)小米推送服務(wù)后才能調(diào)用MiPushClient類的靜態(tài)方法setAlias設(shè)置別名。同樣,設(shè)置別名的結(jié)果將通過PushMessageReceiver繼承類的onCommandResult方法中的MiPushCommandMessage參數(shù)對(duì)象message傳到客戶端??蛻舳岁P(guān)鍵代碼如下:

public void onCommandResult(Context context, MiPushCommandMessage message) {

        String command = message.getCommand();

        List<String> arguments = message.getCommandArguments();

        if (MiPushClient.COMMAND_SET_ALIAS.equals(command)) {

            if (message.getResultCode() == ErrorCode.SUCCESS) {

              mAlias = arguments.get(0);

        }

}

3.成功設(shè)置別名后,服務(wù)器就可以通過這個(gè)別名將消息推送到對(duì)應(yīng)的設(shè)備上。利用別名向設(shè)備推送消息的方法不需要應(yīng)用服務(wù)器保存客戶端上傳的RegID。開發(fā)者可以根據(jù)業(yè)務(wù)的需要給不同設(shè)備設(shè)置不同的別名。注:一臺(tái)設(shè)備可以設(shè)置多個(gè)不同的別名,而一個(gè)別名只能對(duì)應(yīng)某一臺(tái)設(shè)備。如果多臺(tái)設(shè)備設(shè)置同一個(gè)別名,那么只有最后設(shè)置的一臺(tái)設(shè)備生效。

userAccount:針對(duì)多個(gè)設(shè)備推送消息。應(yīng)用只有在成功注冊(cè)小米推送服務(wù)后才能調(diào)用MiPushClient類的靜態(tài)方法setUserAccount設(shè)置userAccount。同樣,設(shè)置userAccount的結(jié)果將通過PushMessageReceiver繼承類的onCommandResult方法中的MiPushCommandMessage參數(shù)對(duì)象message傳到客戶端??蛻舳岁P(guān)鍵代碼如下:

public void onCommandResult(Context context, MiPushCommandMessage message) {

        String command = message.getCommand();

        List<String> arguments = message.getCommandArguments();

        if (MiPushClient.COMMAND_SET_ACCOUNT.equals(command)) {

            if (message.getResultCode() == ErrorCode.SUCCESS) {

              mAccount = arguments.get(0);

        }

}

開發(fā)者可以在不同設(shè)備上設(shè)置同一個(gè)userAccount。然后使用Server SDK給該userAccount發(fā)送消息;此時(shí),所有設(shè)置了該userAccount的設(shè)備都可以收到消息。

4.標(biāo)簽:針對(duì)多個(gè)設(shè)備推送消息。應(yīng)用只有成功注冊(cè)小米推送服務(wù)后才能調(diào)用MiPushClient類的靜態(tài)方法subscribe訂閱標(biāo)簽。同樣,訂閱標(biāo)簽的結(jié)果將通過PushMessageReceiver繼承類的onCommandResult方法中的MiPushCommandMessage參數(shù)對(duì)象message傳到客戶端。客戶端關(guān)鍵代碼如下:

public void onCommandResult(Context context, MiPushCommandMessage message) {

        String command = message.getCommand();

        List<String> arguments = message.getCommandArguments();

        if (MiPushClient.COMMAND_SUBSCRIBE_TOPIC.equals(command)) {

            if (message.getResultCode() == ErrorCode.SUCCESS) {

              mTopic = arguments.get(0);

        }

}

開發(fā)者可以結(jié)合自己的業(yè)務(wù)特征,給用戶打上不同的標(biāo)簽(Topic)。在消息的推送過程中,開發(fā)者結(jié)合每條消息的內(nèi)容和目標(biāo)用戶群,選擇每條消息所對(duì)應(yīng)的標(biāo)簽,可以進(jìn)行更精準(zhǔn)的定向推送。注:一臺(tái)設(shè)備可以訂閱多個(gè)不同的標(biāo)簽,并且一個(gè)標(biāo)簽可以對(duì)應(yīng)多臺(tái)設(shè)備,這點(diǎn)和別名不同。

4.推送消息的類型

用戶成功設(shè)置別名(訂閱標(biāo)簽)后,服務(wù)端可以向該別名(標(biāo)簽)發(fā)送消息。從開發(fā)者網(wǎng)站中下載的包含Server API的jar包只是封裝了一些簡(jiǎn)單的HTTP請(qǐng)求,開發(fā)者可以根據(jù)需要封裝成不同的語言版本。服務(wù)端通過調(diào)用Message.Builder類的passThrough(int)方法設(shè)置pass_through參數(shù)來定義消息的類型,1表示透?jìng)飨ⅲ?表示通知消息。

·透?jìng)飨ⅰ庋b消息的MiPushMessage對(duì)象直接通過PushMessageReceiver繼承類的的onReceivePassThroghMessage方法傳到客戶端。

·通知消息———消息到達(dá)客戶端后會(huì)彈出通知,通知消息到達(dá)時(shí),不需要用戶點(diǎn)擊通知就會(huì)通過PushMessageReceiver繼承類的onNotificationMessageArrived方法傳到客戶端,只有在用戶點(diǎn)擊了通知后封裝消息的MiPushMessage對(duì)象才會(huì)通過PushMessageReceiver繼承類的onNotificationMessageClicked方法傳到客戶端。對(duì)于應(yīng)用在前臺(tái)時(shí)不彈通知類型的通知信息,通知到達(dá)后會(huì)通過PushMessageReceiver繼承類的onNotificationMessageArrived方法傳到客戶端,但不會(huì)觸發(fā)onNotificationMessageClicked方法。注:通知消息通過onNotificationMessageClicked傳到客戶端只對(duì)"自定義點(diǎn)擊行為"有效。注:在MIUI上,如果沒有收到onNotificationMessageArrived回調(diào),是因?yàn)槭褂玫腗IUI版本還不支持該特性,需要升級(jí)到MIUI7之后。非MIUI手機(jī)都可以收到這個(gè)回調(diào)。

客戶端接收消息的關(guān)鍵代碼:

public void onReceivePassThroughMessage(Context context, MiPushMessage message) {

        mMessage = message.getContent();

        if(!TextUtils.isEmpty(message.getTopic())) {

            mTopic=message.getTopic();

        } else if(!TextUtils.isEmpty(message.getAlias())) {

            mAlias=message.getAlias();

        }

    }

public void onNotificationMessageClicked(Context context, MiPushMessage message) {

        mMessage = message.getContent();

        if(!TextUtils.isEmpty(message.getTopic())) {

            mTopic=message.getTopic();

        } else if(!TextUtils.isEmpty(message.getAlias())) {

            mAlias=message.getAlias();

        }

    }

public void onNotificationMessageArrived(Context context, MiPushMessage message) {

        mMessage = message.getContent();

        if(!TextUtils.isEmpty(message.getTopic())) {

            mTopic=message.getTopic();

        } else if(!TextUtils.isEmpty(message.getAlias())) {

            mAlias=message.getAlias();

        }

    }

4.1.透?jìng)飨?/strong>

為了發(fā)送通知消息,服務(wù)端必須調(diào)用Message.Builder類的passThrough(int)方法將參數(shù)pass_through設(shè)置為1。除了需要pass_through參數(shù)外,通知消息還需要設(shè)置一些其他的參數(shù),比如payload、restricted_package_name、registration_id、alias、topic。注:服務(wù)器不需要設(shè)置的title和description,即使設(shè)置了對(duì)客戶端也是無效的。封裝消息的MiPushMessage對(duì)象直接通過PushMessageReceiver繼承類的的onReceivePassThroughMessage方法傳到客戶端。

4.2.通知消息

為了發(fā)送通知消息,服務(wù)端必須調(diào)用Message.Builder類的passThrough(int)方法將參數(shù)pass_through設(shè)置為0。除了需要pass_through參數(shù)外,通知消息還需要設(shè)置一些其他的參數(shù),比如payload、restricted_package_name、registration_id、alias、topic、pass_through、title、description、notify_type等。首先,介紹如何開啟/關(guān)閉app在前臺(tái)時(shí)的通知彈出。應(yīng)用在前臺(tái)的情況下,通知消息到達(dá)客戶端后是否彈出通知可以服務(wù)端來設(shè)置。服務(wù)端調(diào)用Message.Builder類的extra(String key,String value)方法將EXTRA_PARAM_NOTIFY_FOREGROUND的值設(shè)置為"0"或者"1"。當(dāng)EXTRA_PARAM_NOTIFY_FOREGROUND值為”1″時(shí),app會(huì)彈出通知欄消息;當(dāng)EXTRA_PARAM_NOTIFY_FOREGROUND值為”0″時(shí),app不會(huì)彈出通知欄消息。注:默認(rèn)情況下會(huì)彈出通知欄消息。例如:

private Message buildMessage() throws Exception {

     String PACKAGENAME = "com.xiaomi.mipushdemo";

     String messagePayload = “This is a message”;

     String title = “notification title”;

     String description = “notification description”;

     Message message = new Message.Builder()

          .title(title)

          .description(description).payload(messagePayload)

          .restrictedPackageName(MY_PACKAGE_NAME)

          .passThrough(0)

          .notifyType(1)

          .extra(Constants.EXTRA_PARAM_NOTIFY_FOREGROUND, "0")

          .build();

    return message;

}

接下來介紹通知消息的提醒類型和通知消息的點(diǎn)擊行為。

4.2.1.通知消息的提醒類型

通知的提醒類型分為三種:聲音、振動(dòng)和呼吸燈,可以是它們的任一組合。服務(wù)端調(diào)用Message.Builder類的notifyType(int)方法設(shè)置通知的提醒類型。notifyType的值可以是以下幾種的OR組合:

·DEFAULT_SOUND=1;

·DEFAULT_VIBRATE=2;

·DEFAULT_LIGHTS=4;

·DEFAULT_ALL=-1;

另外,服務(wù)端可以調(diào)用Message.Builder類的extra(String key,String value)方法將Constants.EXTRA_PARAM_SOUND_URI的值設(shè)置為對(duì)應(yīng)通知聲音的URI。例如:

private Message buildMessage() throws Exception {

     String PACKAGENAME = "com.xiaomi.mipushdemo";

     String messagePayload = “This is a message”;

     String title = “notification title”;

     String description = “notification description”;

     Message message = new Message.Builder()

          .title(title)

          .description(description).payload(messagePayload)

          .restrictedPackageName(MY_PACKAGE_NAME)

          .passThrough(0)

          .notifyType(1)

          .extra(Constants.EXTRA_PARAM_SOUND_URI, "android.resource://" + PACKAGENAME + "/raw/shaking")

          .build();

    return message;

}

4.2.2.通知消息的點(diǎn)擊行為

通知消息的點(diǎn)擊行為,分為自定義點(diǎn)擊行為和預(yù)定義點(diǎn)擊行為。

4.2.2.1.&nnbsp;自定義點(diǎn)擊行為

用戶點(diǎn)擊了客戶端彈出的通知消息后會(huì)將封裝消息的MiPushMessage對(duì)象通過PushMessageReceiver繼承類的onNotificationMessageClicked方法傳到客戶端。下面介紹一個(gè)應(yīng)用場(chǎng)景。場(chǎng)景1:開發(fā)者希望客戶端在收到消息后啟動(dòng)應(yīng)用的某一個(gè)Activity。解決方法:開發(fā)者可以在onNotificationMessageClicked中調(diào)用context.startActivity方法,將所需要的信息通過Intent傳過去。對(duì)于場(chǎng)景1,如果客戶端工程師不想寫啟動(dòng)actvity的代碼,可以使用下面介紹的預(yù)定義點(diǎn)擊行為。

4.2.2.2.預(yù)定義點(diǎn)擊行為

預(yù)定義點(diǎn)擊行為目前支持三種:(1)打開當(dāng)前的Launcher Activity(2)打開當(dāng)前app內(nèi)的任意一個(gè)Activity(3)打開網(wǎng)頁。服務(wù)端調(diào)用Message.Builder類的extra(String key,String value)方法,將key設(shè)置為Constants.EXTRA_PARAM_NOTIFY_EFFECT,value設(shè)置為Constants.NOTIFY_LAUNCHER_ACTIVITY、Constants.NOTIFY_ACTIVITY或Constants.NOTIFY_WEB以得到不同的預(yù)定義行為。

·Constants.NOTIFY_LAUNCHER_ACTIVITY:打開當(dāng)前app對(duì)應(yīng)的Launcher Activity。

·Constants.ACTIVITY:打開當(dāng)前app內(nèi)的任意一個(gè)Activity。

·Constants.NOTIFY_WEB:打開網(wǎng)頁。

對(duì)于第一種和第二種預(yù)定義的點(diǎn)擊行為,用戶點(diǎn)擊了客戶端彈出的通知消息后會(huì)將封裝消息的MiPushMessage對(duì)象通過Intent傳到客戶端,客戶端在相應(yīng)的Activity中可以調(diào)用Intent的getSerializableExtra(PushMessageHelper.KEY_MESSAGE)方法得到MiPushMessage對(duì)象。而第三種預(yù)定義行為,客戶端是獲取不到MiPushMessage對(duì)象。對(duì)于自定義點(diǎn)擊行為中介紹的場(chǎng)景1,服務(wù)端通過通過Message.Builder的extra方法設(shè)置Constants.EXTRA_PARAM_NOTIFY_EFFECT和Constants.EXTRA_PARAM_INTENT_URI值就可以解決,不需要客戶端添加任何代碼。

5.推送統(tǒng)計(jì)

目前小米推送提供了推送數(shù)據(jù)、消息記錄、用戶數(shù)據(jù)供開發(fā)者查詢。開發(fā)者既可以在小米開發(fā)者中心網(wǎng)站上查看,也可以利用數(shù)據(jù)API獲取。

1.推送數(shù)據(jù)提供當(dāng)日實(shí)時(shí)和歷史每日的已推送總量(區(qū)分群發(fā)和單發(fā))、已送達(dá)消息數(shù)和已點(diǎn)擊數(shù),開發(fā)者可以指定日期查詢相應(yīng)數(shù)據(jù)。

2.用戶數(shù)據(jù)實(shí)時(shí)數(shù)據(jù)提供當(dāng)日實(shí)時(shí)在線用戶數(shù)、截至目前最高在線用戶數(shù);歷史數(shù)據(jù)提供歷史上每天的最高在線用戶數(shù)、新增用戶數(shù)和日活躍用戶數(shù),同樣支持指定時(shí)間段的查詢。注:用戶數(shù)據(jù)中的在線和活躍是以長(zhǎng)連接是否連接為標(biāo)準(zhǔn)的,應(yīng)用不一定啟動(dòng)。

3.消息記錄消息記錄:提供最近30天內(nèi)的消息記錄列表,每條消息提供計(jì)劃推送數(shù)、送達(dá)數(shù)和送達(dá)率、點(diǎn)擊數(shù)和點(diǎn)擊率的統(tǒng)計(jì),支持通過消息id或通知標(biāo)題摘要中的關(guān)鍵詞進(jìn)行查詢。注:為了避免展示用戶較為隱私的信息,計(jì)劃推送數(shù)在10以下的通知我們沒有展示通知的內(nèi)容,也屏蔽了針對(duì)這部分通知內(nèi)容的檢索。

立即登錄,閱讀全文
版權(quán)說明:
本文內(nèi)容來自于小米開放平臺(tái),本站不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。文章內(nèi)容系作者個(gè)人觀點(diǎn),不代表快出海對(duì)觀點(diǎn)贊同或支持。如有侵權(quán),請(qǐng)聯(lián)系管理員(zzx@kchuhai.com)刪除!
相關(guān)文章
雙十一秘籍 | 11月米盟增收指南助你搶占電商大戰(zhàn)先機(jī)
雙十一秘籍 | 11月米盟增收指南助你搶占電商大戰(zhàn)先機(jī)
雙十一即將來臨,電商預(yù)算爭(zhēng)奪戰(zhàn)已經(jīng)打響!
小米開發(fā)者
小米應(yīng)用商店
2024-10-182024-10-18
小米應(yīng)用商店關(guān)于《APP備案標(biāo)準(zhǔn)變更》的公告
小米應(yīng)用商店關(guān)于《APP備案標(biāo)準(zhǔn)變更》的公告
為了保護(hù)用戶權(quán)益,提升用戶體驗(yàn),根據(jù)《工業(yè)和信息化部關(guān)于開展移動(dòng)互聯(lián)網(wǎng)應(yīng)用程序備案工作的通知》,小米應(yīng)用商店新增了APP備案包名與主辦單位的要求,以下是詳細(xì)內(nèi)容。
小米開發(fā)者
小米應(yīng)用商店
2024-10-132024-10-13
App各大應(yīng)用商城的排名被哪些因素影響著?(小米/vivo篇)
App各大應(yīng)用商城的排名被哪些因素影響著?(小米/vivo篇)
小米應(yīng)用商店允許在后臺(tái)設(shè)置關(guān)鍵詞,8個(gè)關(guān)鍵詞,每個(gè)詞不超過5個(gè)字,權(quán)重從左到右逐漸降低。
App
小米應(yīng)用商店
應(yīng)用商店
2024-10-022024-10-02
米盟10月廣告增長(zhǎng)提效指南【附新功能預(yù)告】
米盟10月廣告增長(zhǎng)提效指南【附新功能預(yù)告】
國(guó)慶長(zhǎng)假即將拉開序幕,7天長(zhǎng)假將帶來一波流量的高峰。小米廣告聯(lián)盟(以下簡(jiǎn)稱:米盟)為開發(fā)者伙伴帶來了10月廣告增長(zhǎng)提效指南,內(nèi)含eCPM趨勢(shì)和預(yù)算分布預(yù)估、變現(xiàn)提效Tips、新功能爆料,助力開發(fā)者伙伴在小長(zhǎng)假期間高效地把握預(yù)算節(jié)奏、提前精準(zhǔn)布局,實(shí)現(xiàn)量效雙贏!
小米開發(fā)者
小米應(yīng)用商店
應(yīng)用商店
2024-10-012024-10-01
優(yōu)質(zhì)服務(wù)商推薦
更多