添加开机启动APP Activity或Service的广播不启动的原因

现象

我们知道,在Android中实现开启启动的方法注册一个静态广播去监听开机启动完毕的广播,然后在接听到开机广播完毕后,启动Activity或者Service,方法如下:
首先,新建一个广播监听器监听开机启动完毕的广播

1
2
3
4
5
6
7
8
9
10
11
12
13
public class BootCompletedReceiver extends BroadcastReceiver {

private static final String ACTION_BOOT_COMPLETED = "android.intent.action.BOOT_COMPLETED";

@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(action_boot)){
Intent intent=new Intent(context,MainActivity.class);
ootStartIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);
}
}
}

然后,在AndroidManifest.xml静态注册该广播

1
2
3
4
5
6
<receiver android:name=".BootCompletedReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
<category android:name="android.intent.category.HOME" />
</intent-filter>
</receiver>

最后,在AndroidManifest.xml申请权限

1
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>

通过以上的方法,可以实现开启启动APP,但是,这个方法有问题,以上的方法必须要在安装APP后,手动运行一次APP后,APP才能接收到android.intent.action.BOOT_COMPLETED广播。

假如APP没有Activity,只有Service,或者安装完毕后无法手动运行,也不能通过其他的APP来启动此APP的Service或者Activity,如何安装后,可以开机启动呢?

我们先看看APP接收不到BOOT_COMPLETED广播可能的原因,有以下几种:

  1. BOOT_COMPLETED对应的actionuses-permission没有一起添加
  2. 应用安装到了sd卡内,安装在sd卡内的应用是收不到BOOT_COMPLETED广播的
  3. 系统开启了Fast Boot模式,这种模式下系统启动并不会发送BOOT_COMPLETED广播
  4. 应用程序安装后重来没有启动过,这种情况下应用程序接收不到任何广播,包括BOOT_COMPLETED、ACTION_PACKAGE_ADDED、CONNECTIVITY_ACTION等等。

Android3.1之后,系统为了加强了安全性控制,应用程序安装后或是(设置)应用管理中被强制关闭后处于stopped状态,在这种状态下接收不到任何广播,除非广播带有FLAG_INCLUDE_STOPPED_PACKAGES标志,而默认所有系统广播都是FLAG_EXCLUDE_STOPPED_PACKAGES的,所以就没法通过系统广播自启动了。

所以Android3.1之后:

  1. 应用程序无法在安装后自己启动
  2. 没有ui的程序必须通过其他应用激活才能启动,如它的Activity、Service、Content Provider被其他应用调用。

不过,存在一种例外,就是应用程序被adb push you.apk /system/app/下是会自动启动的,不处于stopped状态。

参考资料:

http://developer.android.com/about/versions/android-3.1.html#launchcontrols
http://commonsware.com/blog/2011/07/13/boot-completed-regression-confirmed.html

1
2
3
/**
* 卡总V5
*/

也就是说,如果需要实现安装APP后,不启动APP,并且实现开机启动APP的方法,出来以上的步骤,还需要一下的步骤:

将APK推送到/system/app目录下,或者打包系统时,将APK放置到/system/app中打包

来源

https://segmentfault.com/a/1190000015851405

文章作者: 二十I邊界
文章链接: https://xuie0000.com/post/2019-12-04-2019/添加开机启动APP-Activity或Service的广播不启动的原因.html
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 二十I邊界