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 逻辑被你成功欺骗

相关推荐
LaughingZhu6 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫6 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
小鹏linux7 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水8 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger8 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)8 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态8 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态8 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart8 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe58 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架