首页
/ jeb2frida 开源项目教程

jeb2frida 开源项目教程

2024-08-15 01:09:37作者:彭桢灵Jeremy

项目介绍

jeb2frida 是一个基于 JEB(Java 反编译器)的脚本工具,旨在自动为 Android 应用程序生成 Frida 钩子代码。通过识别特定的“魔法字符串”(如 OkHttp 中的“Certificate pinning failure”),该工具能够智能定位相关类和方法,进一步依据预设签名匹配参数,最终自动生成 Frida 脚本来拦截和修改目标应用的行为。这一过程简化了传统的手动钩子设置流程,大大提高了研究人员的工作效率。

项目快速启动

安装和配置

  1. 克隆项目

    git clone https://github.com/Hamz-a/jeb2frida.git
    
  2. 安装 JEB: 确保你已经安装了 JEB 反编译器,并将其配置到系统路径中。

  3. 放置脚本: 将 GenerateFridaHooks.py 脚本放置到 JEB 的脚本文件夹中。

使用示例

  1. 编辑脚本: 根据需要编辑 GenerateFridaHooks.py 脚本,配置魔法字符串和签名。

  2. 运行脚本: 在 JEB 中打开目标 APK 文件,然后运行脚本生成 Frida 钩子。

    # 示例代码片段
    # GenerateFridaHooks.py
    def generate_hooks(class_name, method_name):
        # 生成 Frida 钩子代码
        hook_code = f"""
        Java.perform(function() {{
            var {class_name} = Java.use('{class_name}');
            {class_name}.{method_name}.implementation = function() {{
                console.log('[*] {method_name} called');
                return this.{method_name}.apply(this, arguments);
            }};
        }});
        """
        return hook_code
    

应用案例和最佳实践

应用安全审计

jeb2frida 可以快速发现并测试潜在的安全漏洞,如证书绕过。通过自动生成 Frida 钩子,研究人员可以轻松拦截和修改应用的关键行为,从而进行深入的安全分析。

功能行为分析

无需深入阅读每一行 DEX 代码,jeb2frida 即可洞察应用核心功能的操作逻辑。这对于理解复杂应用的内部工作原理非常有用。

教育与培训

jeb2frida 为安全研究新手提供直观的学习案例,展示动态调试的魅力。通过实际操作,新手可以快速掌握移动应用安全分析的基本技能。

典型生态项目

JEB Decompiler

JEB 是一款强大的 Android 反编译器和代码分析工具,jeb2frida 正是基于 JEB 的强大反编译能力开发的。JEB 提供了丰富的 API 和脚本接口,使得 jeb2frida 能够高效地生成 Frida 钩子。

Frida

Frida 是一个动态代码注入工具,允许开发者在运行时修改和拦截应用的行为。jeb2frida 利用 Frida 的动态调试能力,为研究人员提供了一个强大的工具,用于自动化生成 Frida 钩子代码。

通过结合 JEB 和 Frida,jeb2frida 为移动应用安全分析提供了一个全面的解决方案,无论是初学者还是专业人士,都能从中受益。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
51
14
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
289
813
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
483
387
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
110
194
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
58
139
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
364
37
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉Web框架。Rest, 宏路由,Json, 中间件,参数绑定与校验,文件上传下载,MCP......
Cangjie
59
7
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
974
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
96
250
CangjieMagicCangjieMagic
基于仓颉编程语言构建的 LLM Agent 开发框架,其主要特点包括:Agent DSL、支持 MCP 协议,支持模块化调用,支持任务智能规划。
Cangjie
577
41