Android小米推送簡單使用方法
公司項目需要做推送,我們選擇用小米推送,經(jīng)過一段時間的摸索,終于可以簡單的使用小米推送了。
1.創(chuàng)建賬號登入后 登入后選擇消息推送:

2.進入后創(chuàng)建項目,按照步驟創(chuàng)建完后如下

3.后臺配置完了,我們再配置代碼,第一次使用小米推送 我下了個Demo再把里面有用的復制到自己項目中:
先把jar包復制到自己項目中

首先在繼承了Application的類中放入
private static final String APP_ID = "2882303761517483058"; // user your appid the key. private static final String APP_KEY = "5951748376058"; // 此TAG在adb logcat中檢索自己所需要的信息, 只需在命令行終端輸入 adb logcat | grep // com.xiaomi.mipushdemo public static final String TAG = "com.dodonew.epapp";
Id 和key什么的都是在小米開放平臺創(chuàng)建項目獲得的
再在Appliction的oncreate()方法中加入:
if (shouldInit()) {
MiPushClient.registerPush(this, APP_ID, APP_KEY);
}
LoggerInterface newLogger = new LoggerInterface() {
@Override
public void setTag(String tag) {
// ignore
}
@Override
public void log(String content, Throwable t) {
Log.d(TAG, content, t);
}
@Override
public void log(String content) {
Log.d(TAG, content);
}
};
Logger.setLogger(this, newLogger);
if (sHandler == null) {
sHandler = new DemoHandler(getApplicationContext());
}
其中shouldInit()和Handler:
private boolean shouldInit() {
ActivityManager am = ((ActivityManager) getSystemService(Context.ACTIVITY_SERVICE));
List<RunningAppProcessInfo> processInfos = am.getRunningAppProcesses();
String mainProcessName = getPackageName();
int myPid = Process.myPid();
for (RunningAppProcessInfo info : processInfos) {
if (info.pid == myPid && mainProcessName.equals(info.processName)) {
return true;
}
}
return false;
}
public static DemoHandler getHandler() {
return sHandler;
}
public static class DemoHandler extends Handler {
private Context context;
public DemoHandler(Context context) {
this.context = context;
}
@Override
public void handleMessage(Message msg) {
String s = (String) msg.obj;
if (sMainActivity != null) {
sMainActivity.refreshLogInfo();
}
if (!TextUtils.isEmpty(s)) {
// Toast.makeText(context, s, Toast.LENGTH_LONG).show();
}
}
}
說實話Demohander其實沒什么用,主要是彈出toast提示而已,我不喜歡 于是隱藏了toast
其中MainActivity中的refreshLogInfo()方法:
public void refreshLogInfo() {
String AllLog = "";
for (String log : logList) {
AllLog = AllLog + log + "\n\n";
}
System.out.println("mainActivity中消息推送::::::::"+AllLog);
}
然后 我們要把Demo中的一個廣播類復制過來 ,由于內(nèi)容一樣我就不復制了
其中有個方法很重要: onNotificationMessageClicked(Context context, MiPushMessage message)
這個方法的作用是:當有消息推送到你手機上時 你在通知欄點擊這個消息時,就能在這個方法中通過message獲取 消息的內(nèi)容。
第二 加入你想點擊通知欄中的消息 跳轉(zhuǎn)到你app中指定的界面 也在這個方法中執(zhí)行 只需要添加一段代碼即可:
Intent intent = new Intent(context, 指定的Activity.class); intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(intent);
最后 我們要去配置AndroidManifest.xml
一些權(quán)限我就不放了 和以前的權(quán)限放一起了不好區(qū)分,可以去Demo中找
在權(quán)限下面放
<permission android:name="com.dodonew.epapp.permission.MIPUSH_RECEIVE" android:protectionLevel="signature" /> <uses-permission android:name="com.dodonew.epapp.permission.MIPUSH_RECEIVE" /> <uses-permission android:name="android.permission.VIBRATE" />
在<Appliction/>中添加
<service
android:name="com.xiaomi.push.service.XMJobService"
android:enabled="true"
android:exported="false"
android:permission="android.permission.BIND_JOB_SERVICE"
android:process=":pushservice" />
<service
android:name="com.xiaomi.push.service.XMPushService"
android:enabled="true"
android:process=":pushservice" />
<service
android:name="com.xiaomi.mipush.sdk.PushMessageHandler"
android:enabled="true"
android:exported="true" />
<service
android:name="com.xiaomi.mipush.sdk.MessageHandleService"
android:enabled="true" />
<receiver
android:name="com.dodonew.epapp.control.receiver.XiaoMiMessageReceiver"
android:exported="true">
<intent-filter>
<action android:name="com.xiaomi.mipush.RECEIVE_MESSAGE" />
</intent-filter>
<intent-filter>
<action android:name="com.xiaomi.mipush.MESSAGE_ARRIVED" />
</intent-filter>
<intent-filter>
<action android:name="com.xiaomi.mipush.ERROR" />
</intent-filter>
</receiver>
<receiver
android:name="com.xiaomi.push.service.receivers.NetworkStatusReceiver"
android:exported="true">
<intent-filter>
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver>
<receiver
android:name="com.xiaomi.push.service.receivers.PingReceiver"
android:exported="false"
android:process=":pushservice">
<intent-filter>
<action android:name="com.xiaomi.push.PING_TIMER" />
</intent-filter>
</receiver>
就可以了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Android消息推送:手把手教你集成小米推送(附demo)
- Android手機端小米推送Demo解析和實現(xiàn)方法
- Android中利用App實現(xiàn)消息推送機制的代碼
- Android中使用WebSocket實現(xiàn)群聊和消息推送功能(不使用WebView)
- 使用SignalR推送服務在Android的實現(xiàn) SignalA
- Android中使用socket通信實現(xiàn)消息推送的方法詳解
- Erlang實現(xiàn)的百度云推送Android服務端實例
- Android頂欄定時推送消息
- android push推送相關(guān)基本問答總結(jié)
- Android、iOS和Windows Phone中的推送技術(shù)詳解
相關(guān)文章
Android Studio實現(xiàn)簡易進制轉(zhuǎn)換計算器
這篇文章主要為大家詳細介紹了Android Studio實現(xiàn)簡易進制轉(zhuǎn)換計算器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05
Android自定義TextBanner實現(xiàn)自動滾動
這篇文章主要為大家詳細介紹了Android自定義TextBanner實現(xiàn)自動滾動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-07-07
為Android應用增加渠道信息 自動化不同渠道的打包過程的使用詳解
為了統(tǒng)計渠道信息,就不得不在程序的某個地方加入渠道的信息,然后針對不同的渠道打不同的包。一般可以在Manifest文件中加入渠道編號,而不直接寫在代碼中。這樣做的好處是,可以針對不同渠道,自動化去修改Manifest文件中的渠道編號,然后自動為該渠道打包2013-05-05
Kotlin協(xié)程flowOn與線程切換超詳細示例介紹
這篇文章主要介紹了Kotlin協(xié)程flowOn與線程切換,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-09-09

