【冠亚体育手机网站】简单的开机自启

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

今天我们主要来探讨android怎么让一个service开机自动启动功能的实现。Android手机在启动的过程中会触发一个Standard Broadcast Action,名字叫android.intent.action.BOOT_COMPLETED(记得只会触发一次呀),在这里我们可以通过构建一个广播接收者来接收这个这个action.下面我就来简单写以下实现的步骤:
 

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

   
第一步:首先创建一个广播接收者,重构其抽象方法 onReceive(Context context, Intent intent),在其中启动你想要启动的Service或app

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

    import android.content.BroadcastReceiver;
 

如何做到开机启动?

    import android.content.Context;  

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

    import android.content.Intent;  

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

    import android.util.Log;  

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

public class BootBroadcastReceiver extends BroadcastReceiver {  

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

//重写onReceive方法  

复制代码 代码如下:

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

package com.arui.framework.android.daemonservice; 

 //后边的XXX.class就是要启动的服务           

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

  Intent service = new Intent(context,XXXclass);

public class BootBroadcast extends BroadcastReceiver { 

             context.startService(service);
  

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

          Log.v(“TAG”, “开机自动服务自动启动…..”);  

        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); 
        } 

  Intent intent2 =
context.getPackageManager().getLaunchIntentForPackage(packageName);   

    } 

   context.startActivity(intent2 );      

复制代码 代码如下:

         }   

package com.arui.framework.android.daemonservice; 

  }  

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

第二步:配置xml文件,在receiver接收这种添加intent-filter配置  

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

     <receiver android:name=”BootBroadcastReceiver”>  

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

              <intent-filter>  

复制代码 代码如下:

               <action android:name=”android.intent.action.BOOT_COMPLETED”></action>  

package com.arui.framework.android.daemonservice; 

                 <category android:name=”android.intent.category.LAUNCHER” />  

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

            </intent-filter>  

public class DaemonService extends Service { 

           </receiver>  

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

第三步:添加权限 <uses-permission android:name=”android.permission.RECEIVE_BOOT_COMPLETED” />
 

    @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。这样,即使应用被杀死了,隔一段时间,应用还会自动启动。具体的,就不在这里展开了。

您可能感兴趣的文章:

  • Android
    通知使用权(NotificationListenerService)的使用
  • android使用NotificationListenerService监听通知栏消息
  • Android实现Service下载文件,Notification显示下载进度的示例
  • android开发教程之开机启动服务service示例
  • Android中实现开机自动启动服务(service)实例
  • 在Android中 获取正在运行的Service
    实例
  • Android中使用IntentService创建后台服务实例
  • android notification
    的总结分析
  • android中创建通知栏Notification代码实例
  • Android中Notification
    提示对话框
  • Android编程使用Service实现Notification定时发送功能示例

Post Author: admin

发表评论

电子邮件地址不会被公开。 必填项已用*标注