PS:用了一下個推.感覺實現第三方應用的推送功能還是比較簡單的.官方文檔寫的也非常的明確.
學習內容:
1.使用個推實現第三方應用的推送.
所有的配置我最后會給一個源代碼,內部有相關的配置和文檔來幫助大家完成配置,在這里就不進行介紹了.
感覺需要寫的東西不是非常的多,因為官方的文檔已經寫的非常的明確了,如何進行配置,導入jar包,.so文件,以及AndroidManifest的文件的相關配置都寫的非常的明確.我這里就稍微的簡單介紹一下.注冊賬號什么的我就不說了,這些基本的東西沒有減少的必要性.
i.PushManager
PushManager是實現推送的核心類,可以進行推送控制,設置標簽,設置別名,設置默認時間等.所有的接口都由這個對象去調用.因此我們需要初始化PushManager對象.
PushManager.getInstance().initialize(context);
對象的創建方式是單列的.因此拿到的對象也就具有唯一性.這里獲取到PushManager對象的同時去初始化個推服務,接口調用之后個推服務后台運行,通過廣播的方式將CID發送給App.這里其實最重要的就是這個廣播,其他的東西都沒有什么重點的地方.只需要稍微的注意一下即可.
ii.GeTuiPushReceiver app接收CID的廣播
package com.example.totem.getuidemo.receiver; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.os.Bundle; import com.igexin.sdk.PushConsts; import com.igexin.sdk.PushManager; /** * Created by Totem on 2016/8/15. * @author 代碼丶如風 */ public class GeTuiPushReceiver extends BroadcastReceiver { public static String KEY_CLIENT_ID = "push_notification_client_id"; public static String message; public static void init(Context context){ /** * 初始化對象 * 可以進行推送控制,設置標簽,設置別名,設置默認時間等 * 所有接口都由該對象調用 * */ PushManager.getInstance().initialize(context); /** * 獲取ClientId * */ String clientId = PushManager.getInstance().getClientid(context); if(clientId != null){ KEY_CLIENT_ID = clientId; } } @Override public void onReceive(Context context, Intent intent) { //相關處理 } private static OnGetPushMessageListener onGetPushMessageListener; public static void setOnGetPushMessageListener(OnGetPushMessageListener onGetPushMessageListener) { GeTuiPushReceiver.onGetPushMessageListener = onGetPushMessageListener; } /** * 對外暴露接口 * */ public interface OnGetPushMessageListener{ void getOstfMessage(String message); } }
這個廣播是接收推送消息的核心類,其實實現起來也是比較簡單的,首先就是獲取PushManager對象,然后初始化個推服務,在OnReceiver方法中對傳遞過來的數據進行判斷,這里只對兩種狀態進行了判斷,一種是推送通知,另一種則是透傳消息.
@Override public void onReceive(Context context, Intent intent) { Bundle bundle = intent.getExtras(); switch (bundle.getInt(PushConsts.CMD_ACTION)){ /** * 推送通知 * */ case PushConsts.GET_CLIENTID: String cid = bundle.getString("clientid"); break; /** * 透傳消息,傳遞過來的是Json字符串.一般而言需要客戶端進行解析. * */ case PushConsts.GET_MSG_DATA: String appid = bundle.getString("appid"); byte[] payload = bundle.getByteArray("payload"); String taskid = bundle.getString("taskid"); String messageid = bundle.getString("messageid"); if(payload != null){ /** * 如果拿到的數據不為空.那么做相關的處理 * */ message = new String(payload); onGetPushMessageListener.getOstfMessage(message); }else{ message = ""; } break; } }
這樣通過判斷,我們就可以得知,是推送通知,還是透傳消息等等.最后寫了一個對外界暴露的接口,其實就對Activity暴露接口,當我們在廣播中接收到了數據發生了變化,或者是有數據傳遞過來,需要通過這個接口的方式,告知數據產生了變化,需要主進程做相關的處理,這是暴露接口的目的.然后在主頁面中,我們只需要實現這個接口就可以了.
GeTuiPushReceiver.setOnGetPushMessageListener(new GeTuiPushReceiver.OnGetPushMessageListener() { @Override public void getOstfMessage(String message) { if(message!=null){ MessageData.add(message); } } });
iii.打開推送
turnOnPush(context)方法,用於打開推送,如果我們不主動打開推送的話,就算是后台發送了推送消息,我們也是接收不到的.在默認的狀態下是開啟狀態.
GeTuiPushReceiver.init(getApplicationContext()); pushManager = PushManager.getInstance(); pushManager.turnOnPush(this);
iv.關閉推送服務
turnOffPush(context)方法,用於關閉推送服務.這個方法執行之后,就無法收到推送服務了,需要注意的是,想要再次接收到推送,必須使用turnOnPush(context)方法.其他方法無效.
GeTuiPushReceiver.init(getApplicationContext()); pushManager = PushManager.getInstance(); pushManager.turnOffPush(this);
v.停止SDK服務.
stopService(context).停止SDK服務之后,服務不會終止運行,而是終止推送和聯網功能.重新啟動需要調用initalize()方法或者是turnOnPush()方法.
GeTuiPushReceiver.init(getApplicationContext()); pushManager = PushManager.getInstance(); pushManager.stopService(this);
基本的東西都介紹完了,還有一些設置標簽,靜默時間,綁定別名什么的,大家如果有興趣可以自己去研究下,反正我是暫時沒有使用到.因此就先不動這幾個模塊了.我們就來看看如何使用個推后台來實現推送吧.
首先我們需要創建自己的應用,然后我們可以在應用配置當中獲取到我們想要的數據,具體效果如下.
這里有我們想要的數據,AppId,AppKey等等,這些東西都需要在AndroidManifest文件中進行配置.自己做好Demo之后,就可以通過后台發送推送了.
標題和內容都是必填項,然后一直確定就可以了,這樣消息就被推送出去了.在App上打開推送服務,就可以接收到推送了.透傳消息我就不進行截圖了.需要注意的一點就是透傳消息是Json格式的字串.個推為我們提供好了Json的格式化工具.
最后放上一個源代碼,這個源代碼是無法運行的,因為這里是使用我自己的后台,大家也需要去創建賬號,用自己的后台去創建應用,然后把AndroidManifest文件中的AppId,AppKey,AppSecret進行修改.並且內部提供了很多文檔,幫助大家去集成.