分享一下我老师大神的人工智能教程!零基础,通俗易懂!

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!


第一、摘要

今天不是周末,但是我已经放假了,所以就开始我们的技术探索之旅,今天我们来讲一下Android中最期待的技术,就是拦截Activity的启动,其实我在去年的时候,就像实现这个技术了,但是因为知识不充足,就放弃了,当时的需求很简单,就是实现应用锁,就是给每个应用打开的时候加上密码,不了解的同学,可以看看这篇文章:


不过,当时也是实现了,只是使用了监听TopActivity的方式实现的,后台起一个Service来轮询监听。但是当时想到了性能上的问题,因为感觉后台启动一个Service来进行轮询操作会很消耗性能,但是最后发现,现在市场上的应用锁应用实现的原理都是这么做的,所以当时就是用这个技术来做了。但是关于其他方式来做的工作没有断续,现在有时间就来研究一下如何通过拦截Activity的启动方式来实现拦截。因为:监听比轮训机制高效。


第二、前提准备

不过实现了拦截Activity启动技术实现之后,我们还会发现这个技术在很多地方都会用到。关于注入技术需要关注的文章:


看完这篇文章,才能理解注入技术,才能看懂这篇文章。看完这篇文章之后,我们能看到三个文件:

poison; libproxybinder.so; DemoInject3.apk

关于这三个文件的作用就不多说了。看完文章就知道了。


第三、技术解析

涉及到源码类:

ContextImpl.java

ActivityThread.java

Instrumentation.java

ActivityManagerNative.java

那么这里我们现在需要拦截Activity的启动流程的话,那就要看看Activity的启动源代码:

先来看一下ContextImpl.java中的startActivity代码: