資料介紹
軟件簡介
ByteHook(又名 bhook) 是字節(jié)跳動開源的一個針對 Android app 的 PLT hook 框架。它提供了一套 Android app 使用 PLT hook 的整體方案,而不僅僅是替換地址。
字節(jié)跳動的大多數(shù) Android app(包括抖音,今日頭條,西瓜視頻)在線上環(huán)境中使用了 ByteHook 作為 PLT hook 方案。
特征
- 支持 Android 4.1 - 12 (API level 16 - 31)。
- 支持 armeabi-v7a, arm64-v8a, x86 和 x86_64。
- 對同一個函數(shù)的多個 hook 和 unhook 互相不沖突。
- 可以 hook 進(jìn)程中單個、部分或全部的動態(tài)庫。
- 自動 hook 新加載的動態(tài)庫。
- 自動避免代理函數(shù)之間的遞歸調(diào)用和環(huán)形調(diào)用。
- 代理函數(shù)中支持回溯調(diào)用棧。
- 使用 MIT 許可證授權(quán)。
文檔
快速開始
你可以參考?bytehook-sample?中的示例 app。
1. 在 build.gradle 中增加依賴
ByteHook 發(fā)布在?Maven Central?上。為了使用?native 依賴項(xiàng),ByteHook 使用了從?Android Gradle Plugin 4.0+?開始支持的?Prefab?包格式。
allprojects {
repositories {
mavenCentral()
}
}
android { buildFeatures { prefab true } } dependencies { implementation 'com.bytedance:bytehook:1.0.3' }
2. 在 CMakeLists.txt 或 Android.mk 中增加依賴
CMakeLists.txt
find_package(bytehook REQUIRED CONFIG) add_library(mylib SHARED mylib.c) target_link_libraries(mylib bytehook::bytehook)
Android.mk
include $(CLEAR_VARS)
LOCAL_MODULE := mylib
LOCAL_SRC_FILES := mylib.c
LOCAL_SHARED_LIBRARIES += bytehook
include $(BUILD_SHARED_LIBRARY)
$(call import-module,prefab/bytehook)
3. 指定一個或多個你需要的 ABI
android { defaultConfig { ndk { abiFilters 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64' } } }
4. 增加打包選項(xiàng)
如果你是在一個 SDK 工程里使用 ByteHook,你可能需要避免把 libbytehook.so 打包到你的 AAR 里,以免 app 工程打包時遇到重復(fù)的 libbytehook.so 文件。
android { packagingOptions { exclude '**/libbytehook.so' } }
另一方面, 如果你是在一個 APP 工程里使用 ByteHook,你可以需要增加一些選項(xiàng),用來處理重復(fù)的 libbytehook.so 文件引起的沖突。
android { packagingOptions { pickFirst '**/libbytehook.so' } }
5. 初始化
import com.bytedance.android.bytehook.ByteHook; public class MySdk { public static synchronized void init() { ByteHook.init(); } }
6. Hook 和 Unhook
#include "bytehook.h"
bytehook_stub_t bytehook_hook_single( const char *caller_path_name, const char *callee_path_name, const char *sym_name, void *new_func, bytehook_hooked_t hooked, void *hooked_arg); bytehook_stub_t bytehook_hook_partial( bytehook_caller_allow_filter_t caller_allow_filter, void *caller_allow_filter_arg, const char *callee_path_name, const char *sym_name, void *new_func, bytehook_hooked_t hooked, void *hooked_arg); bytehook_stub_t bytehook_hook_all( const char *callee_path_name, const char *sym_name, void *new_func, bytehook_hooked_t hooked, void *hooked_arg); int bytehook_unhook(bytehook_stub_t stub);
這里的三個 hook 函數(shù)分別用于 hook 進(jìn)程中的單個、部分和全部的調(diào)用者動態(tài)庫。
注意:
-
如果需要在代理函數(shù)中調(diào)用原函數(shù),請始終使用?
BYTEHOOK_CALL_PREV()?宏來完成。 -
確保在代理函數(shù)返回前調(diào)用?
BYTEHOOK_POP_STACK()?宏。在 CPP 源文件中,也可以改為在代理函數(shù)的開頭調(diào)用?BYTEHOOK_STACK_SCOPE()?宏。
?
- ChatGPT:AI模型框架研究 9次下載
- x-hook針對Android平臺ELF的PLT hook庫
- Android示波器電路原理圖.pdf 43次下載
- 一種基于框架特征的共指消解方法 7次下載
- Android對內(nèi)核修改的詳細(xì)說明 14次下載
- 內(nèi)核級HOOK的幾種實(shí)現(xiàn)方法與應(yīng)用說明 5次下載
- Android Studio學(xué)習(xí)教程(電子書+源碼)資料下載 0次下載
- android框架與應(yīng)用開發(fā)介紹 7次下載
- 基于微信支付、支付寶支付等第三方支付的Android框架 5次下載
- 基于Android的BATMAN協(xié)議應(yīng)用框架的研究 0次下載
- 基于NDIS-HOOK的個人防水墻設(shè)計(jì) 0次下載
- ANDROID開發(fā)關(guān)鍵技術(shù) 75次下載
- 利用Hook技術(shù)實(shí)現(xiàn)進(jìn)程控制
- PLT-22電力線收發(fā)器與神經(jīng)元芯片的接口
- PLT-22電力線收發(fā)器與神經(jīng)元芯片的接口
- PLT與PLR在SPDIF上的應(yīng)用 563次閱讀
- 二次配工程(Hook-up)介紹-江蘇泊蘇系統(tǒng)集成有限公司 2.1k次閱讀
- Android In Docker 中 Magisk 的部署與簡單應(yīng)用指南 1.8k次閱讀
- 詳解RTOS中的Hook函數(shù) 928次閱讀
- Android App環(huán)境檢測分析 1.7k次閱讀
- qiling框架和AFLplusplus安裝 3.2k次閱讀
- Android中注入型漏洞基礎(chǔ)理論總結(jié) 1.8k次閱讀
- Hook OpenMemory的導(dǎo)出方法名 1.6k次閱讀
- HOOK函數(shù)概述、用途和用法 1.6w次閱讀
- 利用Xposed去hook住Android系統(tǒng)框架層函數(shù)去脫殼 4.7k次閱讀
- 基于Android操作系統(tǒng)實(shí)現(xiàn)車載人機(jī)界面應(yīng)用程序的設(shè)計(jì) 3.3k次閱讀
- Linux內(nèi)核與Android的關(guān)系 4.9k次閱讀
- 基于Android的智能家居終端控制系統(tǒng) 1.1w次閱讀
- android開發(fā)常用詞匯 9.6k次閱讀
- 什么是Hibernate?Hibernate框架架構(gòu)與框架原理分析 5.6k次閱讀
下載排行
本周
- 1矽力杰 Silergy SY7215A 同步升壓調(diào)節(jié)器 規(guī)格書 Datasheet 佰祥電子
- 1.12 MB | 5次下載 | 免費(fèi)
- 2HT81696H 內(nèi)置升壓的30W立體聲D類音頻功放數(shù)據(jù)手冊
- 1.21 MB | 1次下載 | 免費(fèi)
- 3HTA6863 3W超低噪聲超低功耗單聲道D類音頻功率放大器數(shù)據(jù)手冊
- 0.87 MB | 次下載 | 免費(fèi)
- 4南芯 Southchip SC8802C 充電控制器 規(guī)格書 Datasheet 佰祥電子
- 88.16 KB | 次下載 | 免費(fèi)
- 5矽力杰 Silergy SY7065 同步升壓轉(zhuǎn)換器 規(guī)格書 Datasheet 佰祥電子
- 910.67 KB | 次下載 | 免費(fèi)
- 6矽力杰 Silergy SY7066 同步升壓轉(zhuǎn)換器 規(guī)格書 Datasheet 佰祥電子
- 989.14 KB | 次下載 | 免費(fèi)
- 7WD6208A產(chǎn)品規(guī)格書
- 631.24 KB | 次下載 | 免費(fèi)
- 8NB685 26 V,12 A,低靜態(tài)電流,大電流 同步降壓變換器數(shù)據(jù)手冊
- 1.64 MB | 次下載 | 2 積分
本月
- 1EMC PCB設(shè)計(jì)總結(jié)
- 0.33 MB | 12次下載 | 免費(fèi)
- 2PD取電芯片 ECP5702規(guī)格書
- 0.88 MB | 5次下載 | 免費(fèi)
- 3矽力杰 Silergy SY7215A 同步升壓調(diào)節(jié)器 規(guī)格書 Datasheet 佰祥電子
- 1.12 MB | 5次下載 | 免費(fèi)
- 4氮化鎵GaN FET/GaN HEMT 功率驅(qū)動電路選型表
- 0.10 MB | 3次下載 | 免費(fèi)
- 5PD取電芯片,可取5/9/12/15/20V電壓ECP5702數(shù)據(jù)手冊
- 0.88 MB | 3次下載 | 免費(fèi)
- 6SY50655 用于高輸入電壓應(yīng)用的偽固定頻率SSR反激式穩(wěn)壓器英文資料
- 1.01 MB | 3次下載 | 免費(fèi)
- 7怎么為半導(dǎo)體測試儀選擇精密放大器
- 0.65 MB | 2次下載 | 免費(fèi)
- 8SY52341 次級側(cè)同步整流英文手冊
- 0.94 MB | 2次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233095次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191469次下載 | 10 積分
- 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183360次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81606次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73832次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論