前言:
这个世界上手机有三大系统,苹果、 安卓、 中国安卓 。本篇强烈呼吁大家不要去做哪些违反用户体验的黑科技功能,研究研究玩玩就好了啦。全当增长技术,在真实的项目开发中尽量能不用就不要用得好。道理大家都懂的。

目录

那些年Android黑科技①:只要活着,就有希望

  • android应用内执行shell
  • 双进程保活aidl版
  • 双进程保活jni版
  • 保活JobService版

那些年Android黑科技②:欺骗的艺术

  • hook技术
  • 欺骗系统之偷梁换柱

那些年Android黑科技③:干大事不择手段

  • 应用卸载反馈
  • Home键监听
  • 桌面添加快捷方式
  • 无法卸载app(DevicePolicManager)
  • 无网络权限偷偷上传数据

android应用内执行shell

android系统本身是Linux作为内核,我们一般开发中使用 adb shell 命令来操作。但其实本身在应用内也是可以执行的。强大的地方是在root的情况下,可以实现静默安装和操作一切你想在设备内做事情。其方法如下。

调用工具代码:

    /*** 是否是在root下执行命令** @param commands        命令数组* @param isRoot          是否需要root权限执行*/public static void execCmd(String[] commands, boolean isRoot) {//便于观看删除来不影响的部分代码,完整的可以在文中的github里找到。process = Runtime.getRuntime().exec(isRoot ? "su" : "sh");os = new DataOutputStream(process.getOutputStream());for (String command : commands) {if (command == null) continue;os.write(command.getBytes());os.writeBytes("\n");os.flush();}os.writeBytes("exit\n");os.flush();result = process.waitFor();successMsg = new StringBuilder();errorMsg = new StringBuilder();successResult = new BufferedReader(new InputStreamReader(process.getInputStream(), "UTF-8"));errorResult = new BufferedReader(new InputStreamReader(process.getErrorStream(), "UTF-8"));}

没有root权限的情况下在屏幕上操作,实测可被执行的命令只有swipe和部分keyevent可以生效,其余的可以通过adb的方式调用成功。但是一但在应用内通过shell是不可以的。这确保了android手机的安全。

其中keyevent 返回键 音量键可以调用 而home按键这种则不可以。
如果你试图调用dumpsys activity activities 来查看。会抛出权限的异常如下。实测中我有申请权限,但一样无法在应用内部调起。

Permission Denial: can't dump ActivityManager from from pid=12414, uid=10369 without permission android.permission.DUMP0

image.png

使用参考:

Root情况下静默安装:

 String command = "LD_LIBRARY_PATH=/vendor/lib:/system/lib pm install " +"apk路径";ShellUtils.execCmd(command, ture);

代码:https://github.com/BolexLiu/AndroidShell


双进程保活aidl版 (android5.0以下)

原理介绍:实现的机制并不复杂,通过AIDL的方式开启两个服务分别在不同进程中启动,然后互相守护监听对方是否被关闭,如果有一方被断开连接,另一方测重启服务。因为android在5.0之前销毁进程是一个一个销毁的,他并不能同时销毁两个。所以可以做这件事。(被修改的rom除外,比如华为4.4就不行,但三星可以。)

1.配置服务进程。注意process属性会独立在另一个进程中。

    <service android:name=".Service.LocalService" /><service android:name=".Service.RemoteService"  android:process=".Remote"/>

2.我们拥有两个服务LocalService RemoteService。项目运行后第一件事,同时启动服务。

       startService(new Intent(this, LocalService.class));startService(new Intent(this, RemoteService.class));

3.在LocalService中绑定RemoteService并监听对方的创建和销毁,RemoteService中的实现也一样。

    @Overridepublic int onStartCommand(Intent intent, int flags, int startId) {super.onStartCommand(intent, flags, startId);Log.e(TAG, TAG + " onStartCommand");//  绑定远程服务bindService(new Intent(this, RemoteService.class), mLocalServiceConnection, Context.BIND_IMPORTANT);return START_STICKY;}//连接远程服务class localServiceConnection implements ServiceConnection {@Overridepublic void onServiceConnected(ComponentName name, IBinder service) {try {// 与远程服务通信MyProcessAIDL process = MyProcessAIDL.Stub.asInterface(service);Log.e(TAG, "连接" + process.getServiceName() + "服务成功");} catch (RemoteException e) {e.printStackTrace();}}@Overridepublic void onServiceDisconnected(ComponentName name) {// RemoteException连接过程出现的异常,才会回调,unbind不会回调// 监测,远程服务已经死掉,则重启远程服务Log.e(TAG, "远程服务挂掉了,远程服务被杀死");// 启动远程服务startService(new Intent(LocalService.this, RemoteService.class));// 绑定远程服务bindService(new Intent(LocalService.this, RemoteService.class), mLocalServiceConnection, Context.BIND_IMPORTANT);}}

代码:https://github.com/BolexLiu/DoubleProcess


双进程保活jni版 (android5.0以下)

原理介绍:这种双进程守利用了Linux子进程在父进程被干掉后还能运行而实现。所以我们要做的是通过java去fork一段C的代码。通过动态链接库封装起来。然后在C代码里不断轮训父进程的ppid是否存活。如果挂掉了侧重新唤醒。

1.配置服务进程。注意process属性会独立在另一个进程中。

        <serviceandroid:name=".service.DaemonService"android:process=":daemon"></service>

2.在DaemonService里利用静态代码块调起so。

public class DaemonService extends Service{// 便于阅读省略无关代码,详情去移步至github···static {System.loadLibrary("daemon");}
}

3.so中的C代码轮训进程判断是否存活。

 //便于阅读省略无关代码,详情去移步至github···
//fork子进程,以执行轮询任务pid_t pid = fork();LOGI("fork=%d", pid);if (pid < 0) {
// fork失败了} else if (pid == 0) {
// 可以一直采用一直判断文件是否存在的方式去判断,但是这样效率稍低,下面使用监听的方式,死循环,每个一秒判断一次,这样太浪费资源了。int check = 1;while (check) {pid_t ppid = getppid();LOGI("pid=%d", getpid());LOGI("ppid=%d", ppid);if (ppid == 1) {LOGI("ppid == 1");if (sdkVersion >= 17) {LOGI("> 17");int ret = execlp("am", "am", "startservice", "--user", "0","-n", name,(char *) NULL);} else {execlp("am", "am", "startservice", "-n",name,(char *) NULL);LOGI("else");}check = 0;} else {}sleep(1);}}

感谢CharonChui开源代码。处应该有掌声!

代码:https://github.com/CharonChui/DaemonService

保活 JobService版 (android5.0++)

原理: JobService是官方推荐的方式,即使app完成被杀死的状态下也能调用起来,本质是向系统注册一个任务。通过getSystemService拿到系统的JobScheduler。然后通过JobInfo.Buidler进行构造。需要注意的是一定要指定被触发的条件。比如:设备充电中、空闲状态、连接wifi... 非常类似以前的广播保护原理。但是实现不一样。这次是我们反向注册给系统,而不是接收系统的广播。

1.在AndroidManifest进行配置添加permission属性

 <serviceandroid:name=".MyJobService"android:permission="android.permission.BIND_JOB_SERVICE" />

2.MyJobServer继承JobService类:

    @Overridepublic boolean onStartJob(JobParameters params) {//该方法被触发调用 可以做唤醒其他服务的操作return true;}@Overridepublic boolean onStopJob(JobParameters params) {return true;}

3.在合适的地方向系统注册

 JobScheduler scheduler = (JobScheduler) getSystemService(Context.JOB_SCHEDULER_SERVICE);  ComponentName componentName = new ComponentName(MainActivity.this, MyJobService.class);  JobInfo.Builder builder = new JobInfo.Builder(++mJobId, componentName);  String delay = mDelayEditText.getText().toString();  if (delay != null && !TextUtils.isEmpty(delay)) {  //设置JobService执行的最小延时时间  builder.setMinimumLatency(Long.valueOf(delay) * 1000);  }  String deadline = mDeadlineEditText.getText().toString();  if (deadline != null && !TextUtils.isEmpty(deadline)) {  //设置JobService执行的最晚时间  builder.setOverrideDeadline(Long.valueOf(deadline) * 1000);  }  boolean requiresUnmetered = mWiFiConnectivityRadioButton.isChecked();  boolean requiresAnyConnectivity = mAnyConnectivityRadioButton.isChecked();  //设置执行的网络条件  if (requiresUnmetered) {  builder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_UNMETERED);  } else if (requiresAnyConnectivity) {  builder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY);  }  builder.setRequiresDeviceIdle(mRequiresIdleCheckbox.isChecked());//是否要求设备为idle状态  builder.setRequiresCharging(mRequiresChargingCheckBox.isChecked());//是否要设备为充电状态  scheduler.schedule(builder.build());

注意jobScheduler无法兼容Android 5.0以下的设备,可以参考下面的项目,在低版本中也可以使用。

实际测试 :
研究了一段时间发现这个玩意,在国内的厂商定制过后的rom好多不起作用。 比如魅族 和小米上 如果把app杀死以后,这个服务也调用不起来了。但是在模拟器和aosp版本的Rom上是可行的。我测试时用的电池充电状态来调用job服务。

代码:https://github.com/evant/JobSchedulerCompat


第一部分就先到这里。后续还有两篇续集会紧接着营养跟上,如果你觉得不错可以关注我一波点个喜欢神马的哈哈。

作者:香脆的大鸡排
链接:http://www.jianshu.com/p/cb2deed0f2d8
來源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

那些年Android黑科技①:只要活着,就有希望相关推荐

  1. 那些年Android黑科技③:干大事不择手段

    2019独角兽企业重金招聘Python工程师标准>>> "我在发抖么? 你开什么玩笑.我只是在跳愉快的尬舞. 暗影是不会向邪恶势力低头的. 万岁(≧▽≦)/!!" ...

  2. Android 黑科技(设备管理器等)

    > 修改系统位置信息实现自身隐藏功能 Android中Xposed框架篇-修改系统位置信息实现自身隐藏功能-http://www.wjdiankong.cn/android%E4%B8%ADxp ...

  3. Android 黑科技

    标题 进程保活 实现谣传QQ中的手段--"1像素页面保活" 那些年Android黑科技③:干大事不择手段 Ztorg木马分析: 从Android root木马演变到短信吸血鬼 An ...

  4. android 黑科技 hook技术简单示例

    Hook属于android 中的黑科技,一般在逆向研究中使用较多,这几天技术分享会需要分享这个点.趁此机会来try一try. 先说一下Hook 意思,让大家有个初步的认识,要不一脸懵逼,Hook 简单 ...

  5. Android 黑科技保活实现原理揭秘

    一直以来,App 进程保活都是各大厂商,特别是头部应用开发商永恒的追求.毕竟App 进程死了,就什么也干不了了:一旦 App 进程死亡,那就再也无法在用户的手机上开展任何业务,所有的商业模型在用户侧都 ...

  6. Android 黑科技之卸载系统应用(卸载流氓软件)

    黑科技 我们都知道一般预置的 APP 是不能卸载的,需要有 root 权限,今天分享一个命令,帮你卸载那些你想卸载又不能卸载的系统预置的 APP. adb shell pm uninstall [-k ...

  7. Android 黑科技之让进程不被杀掉

    应用背景:休眠进入锁屏状态后,保持录像操作不被中断持续进行. 转载:http://blog.csdn.net/u011277123/article/details/53183178 目前市面上,除了微 ...

  8. windows电脑改装android,黑科技让安卓秒变Windows_平板电脑评测-中关村在线

    ●黑科技让安卓秒变Windows Android系统下虽然也可以高效的处理一些文字性的工作,但日常绝大多数的办公需求都依托于Windows系统.Android+Windows双系统是解决方案之一,但产 ...

  9. 2023年Android黑科技保活方案,应用永生,拒绝强制杀死 最高适配Android 13 小米 华为 Oppo vivo 等最新机型 拒绝强杀 开机自启动 附demo apk 附研究资料

    更新日志 2023年1月22日 更新: 解决由于 google play 新更新的开发者政策导致的下架问题.可稳定上架运行. 2022年7月11日更新: 支持小米 miui 12 设备 简介 2023 ...

最新文章

  1. 推荐7个最新发现的神仙网站,让人心动!
  2. linux添加自己的库,Linux学习笔记——例叙makefile 增加自定义共享库
  3. 程序员入职国企,1周上班5小时,晒出薪资感叹:腾讯当CEO也不去
  4. html文档类型三种,XHTML DTD三种文件类型声明
  5. 禁用app里面的java_java – 我们可以禁用AOP调用吗?
  6. python基础刻意练习--Task 7 文件与文件系统
  7. 布谷鸟哈希函数的参数_CuckooHash(布谷鸟散列)
  8. Linux那些事儿之我是U盘(28)第一次亲密接触(四)
  9. 阿里云域名转京东云服务器配置图
  10. 【计算机视觉】神经网络推理训练
  11. c语言中 x20是什么意思,vivo X20的这些功能,我想给满分。
  12. SView三维轻量化浏览器
  13. 统计学学习笔记——(4)差异性
  14. Runc容器运行过程及容器逃逸原理
  15. HW机试题字符串分割
  16. 坦克世界WOT圣诞碎片抽箱子活动最优策略
  17. 金融图数据库选型工具“LDBC-FinBench”
  18. pymatgen正确安装姿势
  19. ps处理几亿个像素点的照片时,如何保存为几十兆而又很清晰
  20. 诺基亚Lumia920

热门文章

  1. 学习opengl(起步)
  2. Linux企业级项目实践之网络爬虫(28)——爬虫socket处理
  3. 编程方法学24:管理大型数据中的良好软件工程原理
  4. 读书笔记 23种设计模式总结
  5. 数据分析:JSON格式数据
  6. apt-get 与 yum的区别 (转)
  7. 6、VTK基本数据结构
  8. 图像处理之ROI区域裁剪
  9. USTC English Club Note20171013(5)
  10. 科大星云诗社动态20210324