Frida Hook 流程

一、整体流程总览(先建立全局认知)

Frida Hook = 三件事同时成立

① 手机上运行 frida-server

② 电脑上安装 frida / frida-tools

③ 电脑 → 通过 USB / WiFi attach 或 spawn App

二、手机端:安装 & 运行 frida-server(最关键)

把 frida-server.deb 传到手机

下载地址:github.com/frida/frida...

ruby 复制代码
scp frida-server-17.5.2-ios-arm64.deb mobile@192.168.1.11:/private/var/tmp/

发送前要建立与手机的连接

css 复制代码
ssh mobile@192.168.1.11

192.168.1.11是你的手机IP

这时需要输入密码

css 复制代码
mobile@192.168.1.11's password:

输入root用户的密码,

Dopamine 默认:alpine,如果不对可以去Dopamine修改成你自己的密码

如果成功,在终端上能看到:(越狱手机可以下载一个终端Terminal)

bash 复制代码
ls /private/var/tmp | grep frida

在手机上安装 frida-server

csharp 复制代码
su
dpkg -i /private/var/tmp/frida-server-17.5.2-ios-arm64.deb

确认安装成功:

bash 复制代码
which frida-server
# 输出:
/var/jb/usr/sbin/frida-server

启动 frida-server(⚠️ 必须)

bash 复制代码
/var/jb/usr/sbin/frida-server &

验证是否成功:

perl 复制代码
ps -ef | grep frida

你应该看到类似:

bash 复制代码
root   xxxx   /var/jb/usr/sbin/frida-server

确认端口监听(27042)

perl 复制代码
netstat -an | grep 27042

如果有:

复制代码
127.0.0.1.27042 LISTEN

三、电脑端:安装 Frida 工具

1️⃣ 确认 Python 可用

css 复制代码
python3 --version

2️⃣ 安装 frida & frida-tools(用户级,避免权限坑)

css 复制代码
python3 -m pip install --user frida frida-tools

如果 frida 命令找不到:

bash 复制代码
echo 'export PATH="$HOME/Library/Python/3.x/bin:$PATH"' >> ~/.zshrc
source ~/.zshrc

3️⃣ 验证 Frida 版本

css 复制代码
frida --version

👉 必须与你手机上的 frida-server 主版本一致(17.x)

4️⃣ 验证能看到手机

复制代码
frida-ps -U

如果你能看到 App 列表:

bash 复制代码
PID   Name     Identifier
30311 0.test   com.xxxx.test

👉 电脑端 OK

四、准备 Hook 的 JS 脚本(改变工程中isJailbroken的返回值)

javascript 复制代码
if (ObjC.available) {
    console.log("[*] ObjC runtime available");

    var targetMethod = null;

    ObjC.enumerateLoadedClasses({
        onMatch: function (className, methods) {
            if (methods.indexOf("+ isJailbroken") !== -1) {
                try {
                    var cls = ObjC.classes[className];
                    var method = cls["+ isJailbroken"];
                    if (method) {
                        targetMethod = method;
                        console.log("[+] Found:", className, "+ isJailbroken");
                    }
                } catch (e) {}
            }
        },
        onComplete: function () {
            if (!targetMethod) {
                console.log("[-] isJailbroken not found");
                return;
            }

            Interceptor.attach(
                targetMethod.implementation,
                {
                    onLeave: function (retval) {
                        console.log("[*] Original:", retval.toInt32());
                        retval.replace(0); // NO
                        console.log("[*] Bypassed -> NO");
                    }
                }
            );
        }
    });
} else {
    console.log("[-] ObjC runtime not available");
}

五、Hook App

✅ 方式 :Attach

1️⃣ 先手动在手机上打开 App

确保 App 正在前台运行。

2️⃣ Mac 终端执行:

lua 复制代码
frida -U -n com.compass.--test -l bypass_jailbreak.js

看到:

css 复制代码
[*] ObjC runtime available
[+] Found: XXSecurity + isJailbroken

👉 Hook 成功

六、验证 Hook 是否生效

在 App 里触发:

csharp 复制代码
[Security isJailbroken]

Frida 输出:

ini 复制代码
[*] Original: 1
[*] Bypassed -> NO

👉 App 逻辑被你成功欺骗

相关推荐
晨米酱29 分钟前
四、Prettier 编辑器集成指南
前端·代码规范
文心快码BaiduComate34 分钟前
Comate 4.0新年全面焕新!底层重构、七大升级、复杂任务驾驭力跃升
前端·程序员·架构
怪可爱的地球人44 分钟前
uni-app:5 步接入 vite-plugin-uni-pages,用 <route> 自动生成 pages.json
前端
前端Hardy44 分钟前
告别 !important:现代 CSS 层叠控制指南,90% 的样式冲突其实不用它也能解
前端·vue.js·面试
前端Hardy1 小时前
Vue 3 性能优化的 5 个隐藏技巧,第 4 个连老手都未必知道
前端·vue.js·面试
炫饭第一名1 小时前
速通Canvas指北🦮——路径与形状篇
前端·javascript·程序员
DeathGhost1 小时前
CSS container容器查询
前端·css
JarvanMo1 小时前
Flutter:展示大段格式化文本的挑战
前端
兆子龙1 小时前
Node.js ESM Loader Hooks 介绍:用 module.register 做转译、Import Map 与自定义解析
前端
四眼肥鱼1 小时前
flutter 利用flutter_libserialport 实现SQ800 串口通信
前端·flutter