freeBuf
主站

分类

云安全 AI安全 开发安全 终端安全 数据安全 Web安全 基础安全 企业安全 关基安全 移动安全 系统安全 其他安全

特色

热点 工具 漏洞 人物志 活动 安全招聘 攻防演练 政策法规

点我创作

试试在FreeBuf发布您的第一篇文章 让安全圈留下您的足迹
我知道了

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

B(l)utter:一款针对Flutter移动端应用程序的逆向工程分析工具
2024-01-14 00:50:41

关于B(l)utter

B(l)utter是一款针对Flutter移动端应用程序的逆向工程分析工具,当前版本的B(l)utter仅支持Android libapp.so(ARM64),可以帮助广大研究人员对基于Flutter开发的移动端应用程序进行逆向工程分析。

环境搭建

该应用程序使用了C++20的Formatting代码库。并且需要较新版本的C++编译器,例如g++>=13或Clang>=15环境。

我们建议广大研究人员在Linux操作系统上使用B(l)utter。

除此之外,我们还需要安装并配置好Python 3.x环境。

工具安装

广大研究人员可以直接使用下列命令将该项目源码克隆至本地:

git clone https://github.com/worawit/blutter.git

Debian安装(gcc 13)

安装项目所需的构建工具依赖组件:

apt install python3-pyelftools python3-requests git cmake ninja-build \

    build-essential pkg-config libicu-dev libcapstone-dev

Windows安装

首先,我们需要安装最新版本的Visual Studio,并安装"Desktop development with C++"和"C++ CMake tools"插件。

然后安装该工具所需的libcapstone和libicu4c库:

python scripts\init_env_win.py

然后执行"x64 Native Tools Command Prompt"

macOS Ventura安装(clang 15)

安装xCode、clang 15以及其他需要的工具:

brew install llvm@15 cmake ninja pkg-config icu4c capstone

pip3 install pyelftools requests

工具使用

首先,我们需要从目标APK文件中提取出“lib”目录:

python3 blutter.py path/to/app/lib/arm64-v8a out_dir

blutter.py脚本将会自动根据Flutter引擎检测Dart版本,并调用blutter可执行程序从libapp.so中读取目标APK的相关信息。

如果blutter可执行程序搜索的Dart版本数据不存在,脚本将会自动检测Dart源代码并进行代码编译。

工具更新

我们可以使用git pull来更新工具,并使用--rebuild选项运行blutter.py脚本来强制重新构建该工具的可执行程序:

python3 blutter.py path/to/app/lib/arm64-v8a out_dir --rebuild

输出文件

asm/*:包含符号的libapp程序集;

blutter_frida.js:针对目标应用程序的frida脚本模板;

objs.txt:从Object Pool转储的对象;

pp.txt:Object Pool中的全部Dart对象;

目录结构

bin:包含针对每个Dart版本的blutter可执行程序,格式为"blutter_dartvm<ver>_<os>_<arch>" ;

blutter:包含源代码,需要构建Dart VM库;

build:可以在项目构建完成后删除;

dartsdk:包含Dart运行时的输出,可以在项目构建完成后删除;

external:包含仅适用于Windows的第三方库;

packages:包含Dart运行时的静态库;

scripts:包含用于获取/构建Dart的python脚本;

工具开发-生成Visual Studion解决方案

我们建议广大研究人员在Windows上使用Visual Studio来对B(l)utter进行自定义开发,这里可以使用--vs-sln选项来生成一个Visual Studio解决方案:

python blutter.py path\to\lib\arm64-v8a build\vs --vs-sln

许可证协议

本项目的开发与发布遵循MIT开源许可证协议。

项目地址

B(l)utter:【GitHub传送门

# 移动安全 # 逆向工程 # APK逆向 # 逆向分析 # Flutter安全
免责声明
1.一般免责声明:本文所提供的技术信息仅供参考,不构成任何专业建议。读者应根据自身情况谨慎使用且应遵守《中华人民共和国网络安全法》,作者及发布平台不对因使用本文信息而导致的任何直接或间接责任或损失负责。
2. 适用性声明:文中技术内容可能不适用于所有情况或系统,在实际应用前请充分测试和评估。若因使用不当造成的任何问题,相关方不承担责任。
3. 更新声明:技术发展迅速,文章内容可能存在滞后性。读者需自行判断信息的时效性,因依据过时内容产生的后果,作者及发布平台不承担责任。
本文为 独立观点,未经授权禁止转载。
如需授权、对文章有疑问或需删除稿件,请联系 FreeBuf 客服小蜜蜂(微信:freebee1024)
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
相关推荐
  • 0 文章数
  • 0 关注者
文章目录