因为工作需要Hook java中的方法,一开始用的epic,但是稳定性不太好,手动JIT编译有时会失败,导致闪退,并且9.0上hook貌似不管用。
于是就基于一些已有的native hook方案,做了一些改进和完善,并适配了9.0。
该方案只能hook java函数,如果hook c函数,请看gotHook
不过正如epic的作者说的那样,这种方案不支持Hook系统的一些函数。因为这种方案的有一个前提就是方法调用必须是先拿到ArtMethod,再去取entrypoint然后跳转实现调用。但是很多情况下,系统知道你要调用的这个方法的entrypoint是什么,直接写死在汇编代码里,这样方法调用的时候就不会有取ArtMethod这个动作,从而不会去拿被替换的entrypoint,导致Hook失效。不过对我来说已经够用了。
dependencies {
implementation 'com.yanggs:arthook:0.2.7'
}
JXposed.findAndHookMethod(MainActivity.class, "testFun", String.class,int.class,new MethodCallback() {
@Override
protected void beforeHookedMethod(MethodHookParam param) throws Throwable {
super.beforeHookedMethod(param);
Logger.i("beforeHookedMethod:");
}
@Override
protected void afterHookedMethod(MethodHookParam param) throws Throwable {
super.afterHookedMethod(param);
Logger.i("afterHookedMethod:");
}
});