xposed代码分析

代码流程

主要流程有四个:

加载jar包

使用了xposed框架,那么runtimeStart的参数如下,

if (zygote) {

        isXposedLoaded = xposed::initialize(true, startSystemServer, NULL, argc, argv);

        runtimeStart(runtime, isXposedLoaded ? XPOSED_CLASS_DOTS_ZYGOTE : "com.android.internal.os.ZygoteInit", args, zygote);

原始的zygote中,runtimeStart的参数如下,

if (zygote) {

        runtime.start("com.android.internal.os.ZygoteInit", args, zygote);

XPOSED_CLASS_DOTS_ZYGOTE宏定义如下,

#define XPOSED_CLASS_DOTS_ZYGOTE "de.robv.android.xposed.XposedBridge"

runtimeStart打开虚拟机执行de.robv.android.xposed.XposedBridge中的main方法,

初始化相关模块后再调用ZygoteInit.main,执行com.android.internal.os.ZygoteInit中的main方法

赋值callback函数

bool onVmCreated(JNIEnv*) {

    // TODO: Handle CLASS_MIUI_RESOURCES?

    ArtMethod::xposed_callback_class = classXposedBridge;

    ArtMethod::xposed_callback_method = methodXposedBridgeHandleHookedMethod;

    return true;

}

methodXposedBridgeHandleHookedMethod = env->GetStaticMethodID(classXposedBridge, "handleHookedMethod",

        "(Ljava/lang/reflect/Member;ILjava/lang/Object;Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;");

所有被hook过的方法,回调函数都是handleHookedMethod

Hook指定函数

一般的hook指定函数的方法

               findAndHookMethod(ActivityThread.class, "systemMain", new XC_MethodHook() {

在ART中保存hook函数相关信息到XposedHookInfo结构体中

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值