最近有幸负责参与开发公司的CMPP短信网关程序,采用的是Apache Mina框架实现。通过该项目对Socket通信、长连接有了更深一步的理解,于是就想试试将Mina用到Android平台的信息推送上。经过了解发现,目前已经有不少成型的框架能够实现Android平台的信息推送,特别是AndroidPn。
平时我们开发手机客户端,都少不了要于服务器交互,那么当服务器端有新的数据时,客户端是怎么知道的呢?一般可以采用如下两种方式来实现:
1)客户端定期(每隔一段时间,轮询)向服务器发起请求,以检测是否有新的数据。如果轮询的频率太慢,可能导致获取的信息已经过时;如果轮询的频率过快会很耗电、耗手机流量;
2)采用Android的广播机制,拦截服务端发送的短信。即当服务器端有新的数据时,服务器向所有Android客户端发送短信,客户端基于广播机制将短信拦截并通过手机客户端应用呈现。该方案成本较高,需要向电信运营商申请短信发送端口。
以上两种实现方式多少都存在着弊端,并不能真正满足要求,那有没有更好的实现方式呢?当然有,那就是信息推送。推送就意味着当有新的数据时,服务器端会主动将数据“推”到客户端,而不需要客户端不停地检测。这里就不再过多地对“信息推送”进行解释了,下面将直接通过一个AndroidPn示例来演示。
AndroidPn即Android Push Notification,它是Android平台的信息推送框架,基于XMPP协议的Java实现,它包含了完整的服务器端和客户端程序。因此,我们不用开发一行代码,就能体验到信息推送,还在等什么,马上动手吧。AndroidPn框架的下载地址:http://sourceforge.net/projects/androidpn/files/,将以下文件全部下载:
其中,androidpn-server是服务端程序,它包含可执行脚本,能够直接启动运行;android-demoapp是演示示例,一会就直接用它来演示;androidpn-client是客户端源代码,你可以用它来研究androidpn的内部实现。
第一步:启动androidpn服务端程序。即点击运行android-server-0.5.0\bin\run.bat。启动完成后,可以通过浏览器访问到如下界面:
一会就是通过这个界面向Android手机客户端推送信息。
第二步:启动androidpn客户端程序。将下载的androidpn-demoapp解压并导入到eclipse中,如下图所示:
接着将工程中res/raw/androidpn.properties文件里的xmppHost改为10.0.2.2或者你本机的IP地址,如果不明白为什么是10.0.2.2,请参考我博客的这篇文章《[020] Android模拟器访问本地Web应用》。接着在模拟器中运行该程序,截图如下:
第三步:通过androidpn服务配置界面向客户端推送信息。回到第一步在浏览器中显示的配置界面,一共有四个选项卡,分别是Home、Users、Sessions和Notifications。其中,Users和Sessions中显示的是连接到androidpn服务器的客户端信息,因为我们刚才已经在模拟器中运行了androidpn客户端程序,所以Users和Sessions中是能够看到一条记录的,如下图所示:
我们最关心的功能在Notifications中,点击并填入以下推送信息:
点击Submit按钮,信息将会被推送到客户端,这时在模拟器的状态栏中会以通知的形式显示推送信息,点击后能够查看到推送信息的完整内容,因为在推荐界面的URI中填入了网页地址,所以点击OK将会自动打开浏览器访问该地址。
好了,关于Android的信息推送就介绍到这里。接下来需要去深入了解下AndroidPn的实现原理(其实想想也应该与Socket长连接有关),然后再尝试着用Apache Mina来实现信息推送。