解析Android中如何做到Service被关闭后又自动启动的实现方法_Android

首先要说的是,用户可能把这种做法视为流氓软件。大部分时候,程序员也不想把软件做成流氓软件,没办法,领导说了算。

我们在使用某些Android应用的时候,可能会发现安装了某应用以后,会有一些服务也会随之运行。而且,这些服务每次都会随着手机开机而启动。有的服务做的更绝,当用户在运行的服务中手动停止该服务以后,过了一段时间,服务又自动运行了。虽然,从用户的角度来说,这种方式比较流氓。但是,从程序员的角度来说,这是如何做到的呢?经过研究,我发现有一种方式是可以实现的。下面就和大家分享。

先简单介绍,一会儿会贴上全部代码。

如何做到开机启动?

这个比较简单,网上的资料够多,只要实现一个BroadcastReceiver,监听手机启动完成的事件ACTION_BOOT_COMPLETED即可。需要注意的是,好像不能用模拟器,要用手机测试。

那如何做到启动一个Service,并且在用户关闭后能自动又启动了呢?

一般的,都会在上面说到的BroadcastReceiver的实现里面,监听手机启动完成后,启动一个Service,这是一般的做法。问题是,用户能够在服务里看到这个Service是常驻的。如果用户很敏感,就会停止该Service,甚至直接卸载掉相关的应用。那么,怎样才能定期实现某功能,又不让用户直接看到这个Service呢?聪明的你一定立即就想到了,如果不直接启动Service,而是启动一个timmer,或者alarmManager,然后每隔一段时间去启动Service,做完事情以后关闭掉Service就可以了。

还是看下面的全部代码吧,不过多解释了。这些代码中还是有不少概念的,不熟悉AlarmManager、PendingIntent、BroadcastReceiver、Service等等这些概念的同学可以百度一下。

复制代码 代码如下:

package com.arui.framework.android.daemonservice; 

import android.app.AlarmManager; 
import android.app.PendingIntent; 
import android.content.BroadcastReceiver; 
import android.content.Context; 
import android.content.Intent; 
import android.os.SystemClock; 

public class BootBroadcast extends BroadcastReceiver { 

    @Override 
    public void onReceive(Context context, Intent mintent) { 

        if (Intent.ACTION_BOOT_COMPLETED.equals(mintent.getAction())) { 
            // 启动完成  
            Intent intent = new Intent(context, Alarmreceiver.class); 
            intent.setAction("arui.alarm.action"); 
            PendingIntent sender = PendingIntent.getBroadcast(context, 0, 
                    intent, 0); 
            long firstime = SystemClock.elapsedRealtime(); 
            AlarmManager am = (AlarmManager) context 
                    .getSystemService(Context.ALARM_SERVICE); 

            // 10秒一个周期,不停的发送广播  
            am.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, firstime, 
                    10 * 1000, sender); 
        } 

    } 

复制代码 代码如下:

package com.arui.framework.android.daemonservice; 

import android.content.BroadcastReceiver; 
import android.content.Context; 
import android.content.Intent; 

public class Alarmreceiver extends BroadcastReceiver { 
    @Override 
    public void onReceive(Context context, Intent intent) { 

        if (intent.getAction().equals("arui.alarm.action")) { 
            Intent i = new Intent(); 
            i.setClass(context, DaemonService.class); 
            // 启动service   
            // 多次调用startService并不会启动多个service 而是会多次调用onStart  
            context.startService(i); 
        } 
    } 

复制代码 代码如下:

package com.arui.framework.android.daemonservice; 

import android.app.Service; 
import android.content.Intent; 
import android.os.IBinder; 
import android.util.Log; 

public class DaemonService extends Service { 

    @Override 
    public IBinder onBind(Intent intent) { 
        return null; 
    } 

    @Override 
    public void onCreate() { 
        super.onCreate(); 
        Log.v("=========", "***** DaemonService *****: onCreate"); 
    } 

    @Override 
    public void onStart(Intent intent, int startId) { 
        Log.v("=========", "***** DaemonService *****: onStart"); 
        // 这里可以做Service该做的事  
    } 

下面是manifest文件的代码。

复制代码 代码如下:

<receiver  
    android:name=" com.arui.framework.android.daemonservice.BootBroadcast" 
    android:permission="android.permission.RECEIVE_BOOT_COMPLETED"> 
    <intent-filter> 
        <action android:name="android.intent.action.BOOT_COMPLETED" /> 
    </intent-filter> 
</receiver> 
<receiver  
    android:name=" com.arui.framework.android.daemonservice.Alarmreceiver" > 
    <intent-filter> 
        <action android:name="arui.alarm.action" /> 
    </intent-filter> 
</receiver> 
      <service 
          android:name="com.arui.framework.android.daemonservice.DaemonService" > 
      </service> 

继续讨论这个问题。

如果用户停止整个应用(在管理应用程序中停止应用,或者第三方软件停止整个应用),此时整个进程被杀死,所有的服务自然也被杀死了,timmer,或者alarmManager也就停止了。此时就不会再定期启动服务了。

那么,怎么才能做到,用户或者第三方软件无法停止整个应用呢。我们可以再注册一个系统级别的监听(BroadcastReceiver),来监听系统级别的消息,再次启动timmer,或者alarmManager。这样,即使应用被杀死了,隔一段时间,应用还会自动启动。具体的,就不在这里展开了。

时间: 2024-08-03 07:23:40

解析Android中如何做到Service被关闭后又自动启动的实现方法_Android的相关文章

Android中如何做到Service被关闭后又自动启动

如何做到启动一个Service,并且在用户关闭后能自动又启动了呢?   一般的,都会在上面说到的BroadcastReceiver的实现里面,监听手机启动完成后,启动一个Service,这是一般的做法.问题是,用户可以关闭掉该Service.那么怎样才能使它被关闭掉以后,再次启动呢?聪明的你一定立即就想到了,如果不直接启动Service,而是启动一个timmer,或者alarmManager,然后每隔一段时间去启动Service,就可以了. package com.arui.framework.

Android软件启动动画及动画结束后跳转的实现方法_Android

本文实例讲述了Android软件启动动画及动画结束后跳转的实现方法.分享给大家供大家参考,具体如下: 自己写了个小程序,软件启动时,先显示几张图片,每3秒显示一张,图片显示完跳转到首页 1. 图片轮播使用Gallery,用法很简单 GalleryAdapter adapter = new GalleryAdapter(this, mIds); mGallery.setAdapter(adapter); GalleryAdapter是自定义适配器 public class GalleryAdapt

深入android中The connection to adb is down的问题以及解决方法_Android

自己总结的在android中常会出现的不好解决的问题和方法1.报错:BUILD FAILEDD:\workspace\ganji\build.xml:144: The following error occurred while executing this line:D:\workspace\ganji\build.xml:271: Unable to delete file D:\workspace\ganji\tmp\proguard\tmp.jar解决:已经开了一个模拟器了,无法重新编译

Android 中ListView的Item点击事件失效的快速解决方法_Android

在平常的开发过程中,我们的ListView可能不只是简单的显示下文本或者按钮,更多的是显示复杂的布局,这样的话,我们就得自己写布局和自定义adapter了,一般是继承于BaseAdapter,示例代码见下方.写ListView的点击事件时OnItemClickListener,onItemClick方法没有执行,导致ListView中Item条目点击事件失效,而Item中的View点击事件可以在getView方法中进行处理.导致整个Item点击失效的原因多半是由于在[你自己定义的Item中存在诸

android中TabHost的图标(48&amp;#215;48)和文字叠加解决方法_Android

开发过程中,有时候图标稍微大点,比如48×48的时候,文字就会和图标叠加起来,解决方法如下: 复制代码 代码如下: TabWidget tw = tabHost.getTabWidget(); for (int i = 0; i < tw.getChildCount(); i++) {     TextView tv=(TextView)tw.getChildAt(i).findViewById(android.R.id.title);     ImageView iv=(ImageView)t

Android中没有插入SD情况下的文件写入和读取方法_Android

在Android开发时会遇到如下一种场合 希望应用下载到当前应用的根目录下,而非SD卡中 然后可以随时被该应用或其他应用访问这个文件,即具有被全局读取的权限 此时可以利用上下文的本地文件输出流进行文件写入 注意要为文件赋予可写可读的权限,否则当读取该文件时会报错 FileOutputStream fos = context.openFileOutput(saveFileName, Context.MODE_WORLD_WRITEABLE | Context.MODE_WORLD_READABLE

在Android中创建菜单项Menu以及获取手机分辨率的解决方法_Android

  在Activity中覆写下面两个方法: 复制代码 代码如下:   // 创建菜单 @Override public boolean onCreateOptionsMenu(Menu menu) {  menu.add(0, 0, 0, "关于");  // menu.add(int groupId, int itemId, int order, CharSequence title)  menu.add(0, 1, 1, "退出");        return

xml-如何解析 android 中的 XML?

问题描述 如何解析 android 中的 XML? 我需要把下面的 xml 解析 为输出: String id="3" String name="str1" String path="/mnt/sdcard/path2" String type="2" String desc="des3)" 在 android中如何实现呢? <xmldump> <mfs id="3"

Android菜鸟的成长笔记(17)—— 再看Android中的Unbounded Service

原文:Android菜鸟的成长笔记(17)-- 再看Android中的Unbounded Service 前面已经写过关于startService(Unbounded Service)的一篇文章:<Android菜鸟的成长笔记(16)--Service简介>本篇将在这一篇的基础上再来看一下startService的用法.先看一段代码: TestService.java package com.example.myfirstapp; import android.app.Service; imp