美文网首页
Hook技术

Hook技术

作者: Kevin_Lv | 来源:发表于2019-10-17 10:44 被阅读0次

参考:https://www.jianshu.com/p/74c12164ffca?tdsourcetag=s_pcqq_aiomsg

1、hook的定义

hook,钩子。勾住系统的程序逻辑。
在某段SDK源码逻辑执行的过程中,通过代码手段拦截执行该逻辑,加入自己的代码逻辑。

2、使用价值

hook是中级开发通往高级开发的必经之路。
如果把谷歌比喻成 安卓的造物主,那么安卓SDK源码里面就包含了万事万物的本源。
中级开发者,只在利用万事万物,浮于表层,而高级开发者能从本源上去改变万事万物,深入核心。
hook是安卓面向切面(AOP)编程的基础,可以让我们在不变更原有业务的前提下,插入额外的逻辑.
这样,既保护了原有业务的完整性,又能让额外的代码逻辑不与原有业务产生耦合.

3、前置技能

  • java反射 熟练掌握类Class,方法Method,成员Field的使用方法
    源码内部,很多类和方法都是@hide的,外部直接无法访问,所以只能通过反射,去创建源码中的类,方法,或者成员.
  • 阅读安卓源码的能力 hook的切入点都在源码内部,不能阅读源码,不能理清源码逻辑,则不用谈hook.
    其实使用 androidStudio来阅读源码有个坑,,有时候会看到源码里面 "一片飘红",看似是有什么东西没有引用进来,其实是因为有部分源码没有对开发者开放,解决起来很麻烦,
    所以,推荐从安卓官网下载整套源码,然后使用 SourceInsight 查看源码。
    如果不需要跳来跳去的话,直接用 安卓源码网站 一步到位

4、hook通用思路

  1. 根据需求确定 要hook的对象
  2. 寻找要hook的对象的持有者,拿到要hook的对象
    (持有:B类 的成员变量里有 一个是A的对象,那么B就是A的持有者,如下)
    class B{
    A a;
    }
    class A{}
  3. 定义“要hook的对象”的代理类,并且创建该类的对象
  4. 使用上一步创建出来的对象,替换掉要hook的对象

相关文章

  • HOOK

    HOOK 一、HOOK概述 HOOK(钩子) 其实就是改变程序执行流程的一种技术的统称! 二、iOS中HOOK技术...

  • SSDT知识点

    0x00 Hook技术 hook技术分为两块: Ring3层的Hook,俗称应用层hook技术 Ring0层的Ho...

  • 005——HOOK原理

    HOOK概述 HOOK(钩子)其实就是改变程序执行流程的一种技术的统称!HOOK原理 IOS中HOOK技术的几种方...

  • 浅谈android hook技术

    安全博客 > 技术研究 > 浅谈android hook技术 浅谈android hook技术 您当前的位置:...

  • 009--HOOK原理

    一、HOOK概述 HOOK(钩子) 其实就是改变程序执行流程的一种技术的统称! iOS中HOOK技术的几种方式 1...

  • iOS逆向之HOOK原理(十一)

    HOOK概述 HOOK(钩子) 其实就是改变程序执行流程的一种技术的统称! iOS中HOOK技术的几种方式 1、M...

  • HOOK原理

    一、HOOK概述 HOOK(钩子)其实就是改变程序执行流程的一种技术的统称! 二、iOS中HOOK技术的集中方式 ...

  • <安全攻防之HOOK概述>

    HOOK的概述 HOOK(钩子) 其实就是改变程序执行流程的一种技术的统称! iOS中HOOK技术的几种方式 1....

  • 14 - HOOK原理

    HOOK概述 HOOK中文译为“挂钩”或“钩子”。在iOS逆向中是指改变程序运行流程的一种技术。通过HOOK技术可...

  • Hook原理

    HOOK概述 HOOK示意图 iOS中HOOK技术的几种方式 Method Swizzle 2.fishhook ...

网友评论

      本文标题:Hook技术

      本文链接:https://www.haomeiwen.com/subject/cgrmmctx.html