在使用某些Android应用的时候,可能会发现安装了某应用以后,会有一些服务也会随之运行。而且,这些服务每次都会随着手机开机而启动。有的服务做的更绝,当用户在运行的服务中手动停止该服务以后,过了一段时间,服务又自动运行了。虽然,从用户的角度来说,这种方式比较流氓。但是,从程序员的角度来说,这是如何做到的呢?经过研究,发现有一种方式是可以实现的。
先简单介绍:
在手机启动完成后通过Alarmanager来定期(周期性)发送广播启动一个service,后台运行。
1.如何做到开机启动?
比较简单,只要实现一个BroadcastReceiver,×××启动完成的事件ACTION_BOOT_COMPLETED即可,在里面做想做的事情。需要注意的是,好像不能用模拟器,要用手机测试。
2.如何做到启动一个Service,并且在用户关闭后能自动又启动了呢?
一般的,都会在上面说到的BroadcastReceiver的实现里面,×××启动完成后,启动一个Service,这是一般的做法。问题是,用户可以关闭掉该Service。那么怎样才能使它被关闭掉以后,再次启动呢?方法就是:不直接启动Service,而是启动一个timmer或者alarmManager,然后每隔一段时间去启动Service,就可以了。
第一步:创建一个广播,判断开机启动后发送广播,并且每隔十秒钟发送一个
1.package com.arui.framework.android.daemonservice;
2.
3.import android.app.AlarmManager;
4.import android.app.PendingIntent;
5.import android.content.BroadcastReceiver;
6.import android.content.Context;
7.import android.content.Intent;
8.import android.os.SystemClock;
9.
10. public class BootBroadcast extends BroadcastReceiver {
11.
12. @Override
13. public void onReceive(Context context, Intent mintent) {
14.
15. if (Intent.ACTION_BOOT_COMPLETED.equals(mintent.getAction())) {
16. // 启动完成
17. Intent intent = new Intent(context, Alarmreceiver.class);
18. intent.setAction("arui.alarm.action");
19. PendingIntent sender = PendingIntent.getBroadcast(context, 0, intent, 0);
20. long firstime = SystemClock.elapsedRealtime();
21. AlarmManager am = (AlarmManager) context
22. .getSystemService(Context.ALARM_SERVICE);
23.
24. // 10秒一个周期,不停的发送广播
25. am.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, firstime,
26. 10 * 1000, sender);
27. }
28.
29. }
30. }
第二部:创建广播接收器,启动服务
1.package com.arui.framework.android.daemonservice;
2.
3.import android.content.BroadcastReceiver;
4.import android.content.Context;
5.import android.content.Intent;
6.
7.public class Alarmreceiver extends BroadcastReceiver {
8. @Override
9. public void onReceive(Context context, Intent intent) {
10.
11. if (intent.getAction().equals("arui.alarm.action")) {
12. Intent i = new Intent();
13. i.setClass(context, DaemonService.class);
14. // 启动service
15. // 多次调用startService并不会启动多个service 而是会多次调用onStart
16. context.startService(i);
17. }
18. }
19. }
第三部:创建需要启动的服务
1.package com.arui.framework.android.daemonservice;
2.
3.import android.app.Service;
4.import android.content.Intent;
5.import android.os.IBinder;
6.import android.util.Log;
7.
8.public class DaemonService extends Service {
9.
10. @Override
11. public IBinder onBind(Intent intent) {
12. return null;
13. }
14.
15. @Override
16. public void onCreate() {
17. super.onCreate();
18. Log.v("=========", "***** DaemonService *****: onCreate");
19. }
20.
21. @Override
22. public void onStart(Intent intent, int startId) {
23. Log.v("=========", "***** DaemonService *****: onStart");
24. // 这里可以做Service该做的事
25. }
26. }
下面是manifest文件的代码。
1.<receiver
2. android:name=" com.arui.framework.android.daemonservice.BootBroadcast"
3. android:permission="android.permission.RECEIVE_BOOT_COMPLETED">
4. <intent-filter>
5. <action android:name="android.intent.action.BOOT_COMPLETED" />
6. </intent-filter>
7.</receiver>
8.<receiver
9. android:name=" com.arui.framework.android.daemonservice.Alarmreceiver" >
10. <intent-filter>
11. <action android:name="arui.alarm.action" />
12. </intent-filter>
13. </receiver>
14. <service
15. android:name=" com.arui.framework.android.daemonservice.DaemonService" >
16. </service>
需要特殊说明的是,这种方式有很多局限性。
服务被关闭(比如查看正在运行的服务,然后手动关闭) 这么做是可以自动重启的。
而当整个应用被关闭(管理应用程序中停止应用,或者第三方软件停止整个应用) 整个进程被杀死,所有的服务自然也被杀死了,不可能自己再主动重新启动了。
怎么才能做到,用户或者第三方软件无法杀死整个应用,恐怕只能将应用集成到系统中,做成系统级别的应用了。