由于目前的web項目中要用到android手機消息推送,嘗試過很多中方式之后發(fā)現(xiàn),利用androidpn的部分代碼來實現(xiàn)這個功能是比較方便的。經(jīng)過使用tsung進行簡單的壓力測試,證明這個框架能夠滿足大多數(shù)簡單應(yīng)用的需求。
Androidpn包含有server和client兩個包,server部分可以作為服務(wù)器單獨運行,也可以嵌入到web項目的servlet中,在tomcat環(huán)境中與web項目的其他部分交互。androidpn的簡單用法網(wǎng)上已經(jīng)有很多文章介紹,這里就不細說了。主要談?wù)勅绾螌ndroidpn和自己的web程序整合到一起。
Server部分的主要包結(jié)構(gòu)如下:
其中org.androidpn.server.dao,org.androidpn.server.model和org.androidpn.server.service為使用hibernate鏈接數(shù)據(jù)庫并實現(xiàn)簡單的用戶登錄認證,開發(fā)中可以用我們自己的認證模塊替換。剩下的包就是推送的主體實現(xiàn)。
接下來逐個包來看:
1.util包中的類用來加載resources中的配置文件,在配置文件中可指定監(jiān)聽端口和ssl證書目錄等屬性。
2.org.androidpn.server.xmpp包里面定義了一些異常類型,主要是包含有入口類XmppServer,這個類用來啟動和停止server程序。
3.org.androidpn.server.xmpp.auth包里面是認證的一些類,我們自己的認證模塊可以在這里與androidpn進行結(jié)合。
4.org.androidpn.server.xmpp.codec是XMPP協(xié)議的XML文件解析包,server收到和發(fā)送的消息都要通過這個包來進行xmpp協(xié)議編碼和解碼。
5.org.androidpn.server.xmpp.handler包主要是對消息的處理,我們可以針對不同的消息類型定義自己的handler,
6.org.androidpn.server.xmpp.net包負責(zé)維護與client之間的持久連接,并實現(xiàn)了一些傳輸方式供發(fā)送xmpp消息時使用。
7.org.androidpn.server.xmpp.presence里面只包含PresenceManager類,用來維護client的在線狀態(tài)。
8.org.androidpn.server.xmpp.push包里面的NotificationManager類包含有向client發(fā)送消息的接口。
9.org.androidpn.server.xmpp.router包負責(zé)將收到的信息包發(fā)送到相應(yīng)的handler進行處理,是一個路由包。
10.org.androidpn.server.xmpp.session包定義了用來表示持久鏈接的session,每個session包含一條連接的狀態(tài)信息。
11.org.androidpn.server.xmpp.ssl是對連接進行ssl認證的工具包。
server發(fā)送消息的整個流程主要是:
1. NotificationManager的push接口被調(diào)用。
2.使用SessionManager在當(dāng)前session集合中查找相應(yīng)的client鏈接。
3.定義自己的XMPP消息格式并組裝。
4.通過相應(yīng)session,向client發(fā)送消息。
在這個流程中我們需要修改的是步驟3,也就是需要定義和組裝自己的xmpp消息,以便于將適當(dāng)?shù)男畔鞯娇蛻舳瞬⒈阌诳蛻舳私馕觥R粋€簡單的消息組裝例子如下:
- private IQcreateMessageIQ(Stringtitle,Stringmessage,StringuserId,
- Stringjson){
- Elementnotification=DocumentHelper.createElement(QName.get(
- "message" ,INQURIE_NAMESPACE));
- notification.addElement( "title" ).setText(title);
- notification.addElement( "text" ).setText(message);
- notification.addElement( "userId" ).setText(userId);
- notification.addElement( "json" ).setText(json);
- IQiq= new IQ();
- iq.setType(IQ.Type.set);
- iq.setChildElement(notification);
- return iq;
- }
server端接收和處理消息的流程是:
1.connection收到packet,使用tsc.push.server.xmpp.codec解碼。
2.router根據(jù)packet的namespace等信息,將packet路由到相應(yīng)的handler。
3.handler進行處理。
相應(yīng)的router和handler類在androidpn中都有例子可以參考,這里就不貼代碼了。開發(fā)中只要根據(jù)client發(fā)送消息的格式,定義自己的router和handler類,然后在PacketRouter中注冊router,在IQRouter中注冊handler即可。
Client部分的主要包結(jié)構(gòu)如下:
Client 這邊包含有消息的收發(fā),解析以及持久連接的發(fā)起,重連等功能呢,十分強大,我們開發(fā)時完全不用管底層的連接,也不用擔(dān)心斷線,可以專注于業(yè)務(wù)部分的開發(fā)。
同時,代碼結(jié)構(gòu)也很簡單。去除android的Service和BroadCast類以及一些工具類和常量類不談:
1.NotificationIQ,NotificationIQProvider,NotificationPacketListener三個類負責(zé)對收到的Notification格式的消息進行解析和處理,
2.XmppManager是主控制器,NotificationService通過這個類,在后臺維護androidpn連接。
3.PersistentConnectionListener,PhoneStateChangeListener,ReconnectionThread.java三個類則負責(zé)監(jiān)聽手機的狀態(tài)并進行斷線重連。
我們自定義消息時需要定義3個類:在***IQ中定義消息的實體,在***IQProvider中將消息轉(zhuǎn)化為***IQ實體,在***PacketListener中對實體進行處理,具體的實現(xiàn)可參考NotificationIQ,NotificationIQProvider,NotificationPacketListener三個類。在定義這些類之后,還需要在XmppManager中將這3個類中注冊到connection中,代碼如下:
- //ConnectTask
- <spanstyle= "white-space:pre" ></span>connection.connect();
- Log.i(LOGTAG, "XMPPconnectedsuccessfully" );
- //packetprovider
- ProviderManager.getInstance().addIQProvider( "message" ,
- Constants.NOTIFICATION_NAMESPACE,
- new NotificationIQProvider());
- //LoginTask
- <spanstyle= "white-space:pre" ></span> //packetfilter
- PacketFilterpacketFilter= new PacketTypeFilter(
- NotificationIQ. class );
- //packetlistener
- PacketListenerpacketListener=xmppManager
- .getNotificationPacketListener();
- connection.addPacketListener(packetListener,packetFilter);
以上就是我在開發(fā)過程中的一些體會,有不對的地方希望大家指正~
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

