现象
我们知道,在Android中实现开启启动的方法注册一个静态广播去监听开机启动完毕的广播,然后在接听到开机广播完毕后,启动Activity或者Service,方法如下:
首先,新建一个广播监听器监听开机启动完毕的广播
1 | public class BootCompletedReceiver extends BroadcastReceiver { |
然后,在AndroidManifest.xml静态注册该广播
1 | <receiver android:name=".BootCompletedReceiver"> |
最后,在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广播可能的原因,有以下几种:
BOOT_COMPLETED
对应的action
和uses-permission
没有一起添加- 应用安装到了sd卡内,安装在sd卡内的应用是收不到BOOT_COMPLETED广播的
- 系统开启了Fast Boot模式,这种模式下系统启动并不会发送BOOT_COMPLETED广播
- 应用程序安装后重来没有启动过,这种情况下应用程序接收不到任何广播,包括BOOT_COMPLETED、ACTION_PACKAGE_ADDED、CONNECTIVITY_ACTION等等。
Android3.1之后,系统为了加强了安全性控制,应用程序安装后或是(设置)应用管理中被强制关闭后处于stopped状态,在这种状态下接收不到任何广播,除非广播带有FLAG_INCLUDE_STOPPED_PACKAGES
标志,而默认所有系统广播都是FLAG_EXCLUDE_STOPPED_PACKAGES
的,所以就没法通过系统广播自启动了。
所以Android3.1之后:
- 应用程序无法在安装后自己启动
- 没有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 | /** |
也就是说,如果需要实现安装APP后,不启动APP,并且实现开机启动APP的方法,出来以上的步骤,还需要一下的步骤:
将APK推送到/system/app目录下,或者打包系统时,将APK放置到/system/app中打包