概述:
首先简单阐述一下我对于消息推送的理解,这里拿QQ来举例吧,当我们手机端的QQ离线了,并且退出了QQ应用,但是这时候如果别人给我们发了信息,我们没有上线。服务器会将发送者发送的信息推送过来然后我们发布通知来显示通知我们的用户
原理简单阐述:
通过以上概述,我们基本了解我们需要一个独立进程的后台服务,在AndroidManifest
.xml中注册Service时,有一个android:process属性这个属性有2种情况,即为.和:两种,其中.代表为此服务开启一个全局的独立进程,如果以:开头则为此服务开启一个为此应用私有的独立进程
编码实现:
ServerPushService文件:
01
<strong>importandroid.app.Notification;
02
importandroid.app.NotificationManager;
03
importandroid.app.PendingIntent;
04
importandroid.app.Service;
05
importandroid.content.Intent;
06
importandroid.os.IBinder;
07
08
publicclassServerPushServiceextendsService{
09
//获取消息线程
10
privateMessageThread messageThread =null;
11
//点击查看
12
privateIntent messageIntent =null;
13
privatePendingIntent messagePendingIntent =null;
14
//通知栏消息
15
privateintmessageNotificationID =1000;
16
privateNotification messageNotification =null;
17
privateNotificationManager messageNotificationManager =null;
18
@Override
19
publicIBinder onBind(Intent intent) {
20
returnnull;
21
}
22
@Override
23
publicintonStartCommand(Intent intent,intflags,intstartId) {
24
//初始化
25
messageNotification =newNotification();
26
messageNotification.icon = R.drawable.ic_launcher;//通知图片
27
messageNotification.tickerText ="新消息";//通知标题
28
messageNotification.defaults = Notification.DEFAULT_SOUND;
29
messageNotificationManager = (NotificationManager) getSystemService(this.NOTIFICATION_SERVICE);
30
//点击查看
31
messageIntent =newIntent(this,MessageActivity.class);
32
messagePendingIntent = PendingIntent.getActivity(this,0, messageIntent,0);
33
//开启线程
34
MessageThread thread =newMessageThread();
35
thread.isRunning =true;
36
thread.start();
37
returnsuper.onStartCommand(intent, flags, startId);
38
}
39
40
/***
41
* 从服务端获取消息
42
* @author zhanglei
43
*
44
*/
45
classMessageThreadextendsThread{
46
//运行状态
47
publicbooleanisRunning =true;
48
@Override
49
publicvoidrun() {
50
while(isRunning){
51
try{
52
//休息10秒
53
Thread.sleep(10000);
54
if(getServerMessage().equals("yes")){
55
//设置消息内容和标题
56
messageNotification.setLatestEventInfo(ServerPushService.this,"您有新消息!","这是一条新的测试消息", messagePendingIntent);
57
//发布消息
58
messageNotificationManager.notify(messageNotificationID, messageNotification);
59
//避免覆盖消息,采取ID自增
60
messageNotificationID++;
61
}
62
}catch(Exception e) {
63
e.printStackTrace();
64
}
65
}
66
}
67
}
68
/***
69
* 模拟了服务端的消息。实际应用中应该去服务器拿到message
70
* @return
71
*/
72
publicString getServerMessage(){
73
return"yes";
74
}
75
} </strong>
注册该service在一个单独的进程中
1
<strong><!-- 为此应用私有的独立进程 -->
2
<service
3
android:name="com.jay.serverpush.ServerPushService"
4
android:process=":message"
5
>
6
</service> </strong>
说明:该文件编写了一个service用于后台运行,在manifest里面将该service声明成progress为:开头的,这样在一个单独的进程里面运行,以实现在程序关闭之后达到进程不关闭的目的以此来实现离线推送的目的,编码中的注释很明确,扫描服务器、判断逻辑发布通知等,注释很明确在此不在阐述
1
<strong>@Override
2
protectedvoidonCreate(Bundle savedInstanceState) {
3
super.onCreate(savedInstanceState);
4
setContentView(R.layout.activity_main);
5
this.startService(newIntent(this,ServerPushService.class));
6
}
7
8
9
this.startService(newIntent(this,ServerPushService.class)); </strong>
通过这句话在第一次进入oncreate方法就开启了单独进程的服务