为了账号安全,请及时绑定邮箱和手机立即绑定

您好,请问xposed可以hook所有的java函数吗?为什么?

您好,请问xposed可以hook所有的java函数吗?为什么?

蓝山帝景 2022-01-20 11:30:42
最近在研究关于短信安全的东西,用的是xposed框架。有个问题就是,xposed可以hook任意的java函数么
查看完整描述

2 回答

?
繁花不似锦

TA贡献1851条经验 获得超4个赞

Cydia Substrate是一个代码修改平台。它可以修改任何主进程的代码,不管是用Java还是C/C++(native代码)编写的。而Xposed只支持 HOOK app_process中的java函数,因此Cydia Substrate是一款强大而实用的HOOK工具。

Substrate几个重要API介绍

MS.hookClassLoad

函数原型:void hookClassLoad(String name, MS.ClassLoadHook hook);

该方法实现在指定的类被加载的时候发出通知。因为一个类可以在任何时候被加载,所以Substrate提供了一个方法用来检测用户感兴趣的类何时被加载。



查看完整回答
反对 回复 2022-01-23
?
陪伴而非守候

TA贡献1757条经验 获得超8个赞

 首先解释下dalvik虚拟机中的Method结构体,Method结构体声明在源码目录树下的dalvik/vm/oo/Object.h文件内,在dalvik的世界中,每一个java方法都有一个对应的Method对象,
  dalvik虚拟机在执行java方法时,就会通过该方法的Method对象调用到方法的具体实现代码,Method结构体内有个成员,名位insns,该字段保存着java方法具体的实现代码。那么我今天提供的这个dalvik hook的实现原理就是通过修改Method对象中的insns字段的值来达到hook java的目的。

  这里简短的用文字的形式描述下Hook的实现过程。

  现在有一个返回字符串的函数原型声明为:
  public String truth()
  {
  return "hello from truth";
  }
  另外声明一个方法为:
  public String fake()
  {
  return "fake string";
  }
  之后,该类被加载后,分别获得truth和fake方法的Method对象,并将fake方法的实现代码赋值给truth的Method对象,之后,应用程序调用truth方法时,获得的字符串为"fake string"。


查看完整回答
反对 回复 2022-01-23
  • 2 回答
  • 0 关注
  • 469 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号