Android 进程常驻(5)----开机广播的简单守护以及总结

这是一个轻量级的库,配置几行代码。就能够实如今android上实现进程常驻,也就是在系统强杀下,以及360获取root权限下。clean master获取root权限下都无法杀死进程

支持系统2.3到6.0

支持大部分设备,包含三星。华为。oppo,nexus。魅族等等

能够简单对开机广播进行保护

github地址:

https://github.com/Marswin/MarsDaemon

原理分析:

Android 进程常驻(0)----MarsDaemon使用说明

Android 进程常驻(1)----开篇

Android 进程常驻(2)----细数利用android系统机制的保活手段

Android 进程常驻(3)----native保活5.0下面方案推演过程以及代码详述

Android 进程常驻(4)----native保活5.0以上方案推演过程以及代码详述

Android 进程常驻(5)----开机广播的简单守护以及总结

正文:

最终一口气写完了。这是去年在一个月搞的成果。也算是对自己有了一个交代。

事实上保活就是两个要点:

1、如何监听到进程挂掉

2、如何把进程拉起来

把这两个点都解决,问题就攻克了。

大家把我之前的文章都看完。会发现这两个点上都有好多种策略,那么在不同的手机上。两个点的不同策略就有多种组合方式。也也是我适配手机的主要手段。

当时我适配測试的手机有

还要说一句,有的手机会在你系统设置force close的时候,显示已经杀掉了进程。可是事实上没有真的杀掉,比方魅族。。

能够shell进去用命令 ps | grep mars来查看全部MarsDaemon的进程

假设有root权限,能够使用kill -9命令来杀进程,可是效果没有force close和360\cm 杀的好

最后要说一下。进程常驻是保证不死。可是首先要活一次才行

换句话说好多人问我是不是要开机的时候启动一次,怎么启动

答案肯定是开机广播

可是如今有第三方软件获取root权限之后能够把我们的开机广播给禁掉。那么MarsDaemon的保护活也就没有意义了

那么360/cm是怎么禁用我们的广播的呢?

我们站在他的角度来思考这个问题:

1、他阻止系统发出开机广播,开机之后立马注入SystemService

2、系统发出广播,他让我们收不到

3、我们收到广播之后,他把我们return掉

4、他没能return掉我们,可是立刻杀掉我们

ok。第一个太难,假设他能做到,我们没有root所以无解。

第四个我们没有威胁。由于MarsDaemon就是用来反被杀的

第三个他要注入我们,能够加壳之类防御

那么第二个他是怎么做的呢? 系统方法:

没错,他能够将一个组件设置为enable或者disable。假设把我们的开机广播设置为disable,那么无疑是用不了。

但是这个他们调用不了的,须要系统签名才行。

可是他们能够用android shell中的pms 的pm命令达到相同的效果:

仅仅要有root权限就能够使用这个pm disable componentsName命令。

第三方安全软件,我们已经默认他们有root权限了,那么我们该怎么办呢?

MarsDaemon在project里面有这样一个类

/MarsDaemon/LibMarsdaemon/src/main/java/com/marswin89/marsdaemon/PackageUtils

是的,由于是我们自己的组件。所以设置他不须要不论什么权限,仅仅须要在有些时机顺便重置一下开机广播的状态就好(比方每次进程重新启动的时候,网络变化的时候,开关屏的时候)。另一个就是注冊一个关机广播,每次关机的时候重置一下开机广播的状态。从而达到保护开机广播的作用。

在CleanMaster ,给了root权限之后,禁用开机广播,然后重新启动手机,开机广播失效;然后加上我的这种方法,再禁用掉,开机广播ok。

非常easy的一个小tip

时间: 2024-10-12 21:50:43

Android 进程常驻(5)----开机广播的简单守护以及总结的相关文章

Android 进程常驻----开机广播的简单守护以及总结

这是一个轻量级的库,配置几行代码,就可以实现在Android上实现进程常驻,也就是在系统强杀下,以及360获取root权限下,clean master获取root权限下都无法杀死进程 支持系统2.3到6.0 支持大部分设备,包括三星,华为,oppo,nexus,魅族等等 可以简单对开机广播进行保护 github地址: https://github.com/Marswin/MarsDaemon 原理分析: Android 进程常驻(0)----MarsDaemon使用说明 Android 进程常驻

Android 进程常驻(虽然不可用,但是还是保留下。)

github地址: https://github.com/Marswin/MarsDaemon 原理分析: Android 进程常驻(0)----MarsDaemon使用说明 Android 进程常驻(1)----开篇 Android 进程常驻(2)----细数利用android系统机制的保活手段 Android 进程常驻(3)----native保活5.0以下方案推演过程以及代码详述 Android 进程常驻(4)----native保活5.0以上方案推演过程以及代码详述 Android 进程

Android 进程常驻(0)----MarsDaemon使用说明

版权声明:本文为博主原创文章,未经博主允许不得转载. 这是一个轻量级的库,配置几行代码,就可以实现在Android上实现进程常驻,也就是在系统强杀下,以及360获取root权限下,clean master获取root权限下都无法杀死进程 支持系统2.3到6.0 支持大部分设备,包括三星,华为,oppo,nexus,魅族等等 可以简单对开机广播进行保护 github地址: https://github.com/Marswin/MarsDaemon 原理分析: Android 进程常驻(0)----

Android 进程常驻----native保活5.0以上方案推演过程以及代码

正文: 上一篇我们通过父子进程间建立双管道,来监听进程死掉,经过测试,无耗电问题,无内存消耗问题,可以在设置中force close下成功拉起,也可以在获取到root权限的360/cleanmaster下成功存活. 可是放到5.0+的系统就不能用了,为什么呢?我们来看源码4.4系统和5.0系统在系统force close的时候都做了什么修改. 4.4.3的ActivityManagerService . 实现在这里 然后5.0的AMS 实现 可以看出来5.0的源码中系统强杀的时候会连同同grou

Android进程保活

Android进程回收机制 Low Memory Killer 微信团队原创分享:Android版微信后台保活实战分享(网络保活篇) 微信团队原创分享:Android版微信后台保活实战分享(进程保活篇) 关于 Android 进程保活,你所需要知道的一切 (同上: Android进程保活详解,一篇文章解决你的所有疑问) Android后台保活实践总结:即时通讯应用无法根治的“顽疾” Android 进程常驻----MarsDaemon使用说明

Android 4.0及以上版本接收开机广播BOOT_COMPLETED、开机自启动服务

情景概要:自己做的一个项目的时候,或得不到开启启动的通知,这样更别说开机启动通知里面实现开机服务功能了,查找了N多资料,说法不一,太多的人说4.0之后无法获得开机通知,通过各种渠道,各种大牛的方式仍然是那些N多人说不可行的方法,即使大牛给的是英文文档也是说这样可以的. 最后发现,开启启动通知已经实现了,但是自己的疏忽没有发现,我通过在通知里面弹出一个Toast,但是真机或者模拟器在开机的时候都需要很多启动项,导致最后的Toast弹出很晚,而自己却没看见.你可以在通知里面弹出10个以上的Toast

android 4.0.3开机时不能收到广播

====================问题描述==================== 在android 4.0.3的手机上,receiver在手机开机后收不到启动广播,代码如下: 配置文件:   <receiver android:name=".Boot_test" >         <intent-filter  >              <action android:name="android.intent.action.BOOT

Android 监听开机广播启动服务 动态注册时间变化监听广播

开机广播权限 <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> 开机广播 注册 <receiver android:name="com.stone.receiver.BootedReceiver"> <intent-filter> <action android:name="android.intent.acti

Android静默安装及开机自启的简单实现

写在前面 [apk静默安装]是android应用的一个重要功能,一般用在app自动更新等方面.静默安装在android里面是指不需要界面或用户参与的app安装动作,且需要系统已获root权限.安装完成后一般通过接收广播的方式启动App服务. [app自启动]是常用功能,一般通过接收系统启动广播实现. 正文 1.被执行安装 app: a. 自定义权限 <permission android:name="app.permission.install" android:protecti