简介
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.)(outerclassna |

本文介绍了Lancet,一个轻量级的Android AOP框架,以其快速编译、简洁API和无多余代码插入apk等优点。内容包括Lancet的简单使用、注解和方法、工作原理、实战示例以及使用过程中的注意事项,如This的限制、Proxy的使用和编译错误的解决方法。
最低0.47元/天 解锁文章
854

被折叠的 条评论
为什么被折叠?



