简介
Lancet 是一个轻量级Android AOP框架,比AspectJ更容易上手,并且工程编译出错率也低很多。
优点:
- 编译速度快, 并且支持增量编译(当使用 Scope.LEAF、Scope.ALL 覆盖的类有变动 或者修改 Hook 类时, 本次编译就会变成全量编译)
- 简洁的 API, 几行 Java 代码完成注入需求.
- 没有任何多余代码插入 apk,符合程序设计的开闭原则
- 支持用于 SDK, 可以在SDK编写注入代码来修改依赖SDK的App
缺点:
- 功能简单,仅支持hook具体的方法
简单使用
- 配置
工程的build.gradle中加入:
dependencies {
classpath 'me.ele:lancet-plugin:1.0.6'
}
主module的build.gradle中加入:
apply plugin: 'me.ele.lancet'
使用到Lancet的module的build.gradle中加入:
provided 'me.ele:lancet-base:1.0.6'
- 编写代码
public class TestAop {
//Hook方法的方法名可以与原方法不一样,但是其他都必须一致
@Proxy("i")
@TargetClass("android.util.Log")
public static int logI(String tag, String msg){
tag = tag + "_Smart";
return (int) Origin.call();
}
}
- 运行结果
I/MainActivity_Smart: onCreate
注解和方法
注解名 | 作用 | 参数 |
---|---|---|
@TargetClass | 指定将要被织入代码目标类 | value:目标类全称 Scope:其他继承自目标类的匹配规则 |
@Proxy | 需要替换目标类里的目标方法 | value: 目标方法名 |
@Insert | 需要插入代码的目标类里的目标方法 | value:目标方法名 |
@ClassOf | 当方法参数无法直接声明时指定类路径 | value:类的路径,如果是某个类的子类则用" " 拼 接 , 拼 接 规 则 : ( p a c k a g e n a m e . ) ( o u t e r c l a s s n a m e "拼接,拼接规则:(package_name.)(outer_class_name "拼接,拼接规则:(packagename.)(outer |