type
status
date
slug
summary
tags
category
icon
password
- MethodSwizzle
- fishhook
- Cydia Substrate
- category ovveride
fishhook
使用
验证
data:image/s3,"s3://crabby-images/6e22c/6e22cdef5fc1dd822b22378d911a462d9994202b" alt="notion image"
查看Demo所在的地址空间:
data:image/s3,"s3://crabby-images/f61c7/f61c751a05538ea53bc7310a772450e3b448dc8d" alt="notion image"
将编译后的 Product下FishhookDemo.app,查看其内容,将
FishhookDemo
拖入 MachOView 工具,查看 Lazy Symbol Pointers 下的 NSLog的偏移。data:image/s3,"s3://crabby-images/efa4c/efa4c13bf1ada3e2bc046659031ce52c8a6c368e" alt="notion image"
查看
有几个需要说明的点:
x
是查看地址的命令,即 memory read
dis -s
是查看汇编指令
- iOS 是小端序,所以地址要从右往左读取,如下:
data:image/s3,"s3://crabby-images/bf183/bf183eaeb30b6f9e6943dfc0cc0925c9060b7278" alt="notion image"
原理
fishhook 是如何通过字符串找到函数的呢?
data:image/s3,"s3://crabby-images/119bf/119bf7972529cab6e593f20d4dea9673559822f2" alt="notion image"
懒加载符号表(Lazy Symbol Pointers)开始入手。懒加载符号表里面第一个符号是 NSLog 的指针。这个懒加载符号表有一个与之一一对应的符号表(Indirect Symbols)。
data:image/s3,"s3://crabby-images/2719d/2719d7336309be2c8e58dbd17f99b4b06b510500" alt="notion image"
InDirect Symbols 找到对应符号的偏移量,如下图选中,其 Data 中的值:000000ED,十进制是 237,就是在 Symbol Table 中的序号。
data:image/s3,"s3://crabby-images/f2736/f27367b714c9d2f008056163a188800574d6e2b3" alt="notion image"
在 Symbol Table 中找到 第237个,如下图,其中第一行显示了NSLog 在 String Table 中的偏移,即 000000DB。
data:image/s3,"s3://crabby-images/1609b/1609b43808994c98f1ece4df064034596f2166ea" alt="notion image"
根据上一步找到的偏移量000000DB,以及 String Table 自身的偏移量00008820(第一行),得到 NSLog 函数最后的偏移量:88
00008820+000000DB=000088F8,在下图中,改地址,就在选中行。
_ 是函数的开始,. 是分隔符 。5F是从 _开始,往后依次 _NSLog
data:image/s3,"s3://crabby-images/8917b/8917b73ab5d30d2605fc7c78d1a3e791b09a648c" alt="notion image"
代码研读
框架
参考
链接
代码