bytedance / bhook
- воскресенье, 15 августа 2021 г. в 00:27:12
🔥 bhook is a PLT hook framework for Android app.
bhook is a PLT hook framework for Android app.
bhook is published on Maven Central, and uses Prefab package format for native dependencies, which is supported by Android Gradle Plugin 4.0+.
allprojects {
repositories {
mavenCentral()
}
}
android {
buildFeatures {
prefab true
}
}
dependencies {
implementation 'com.bytedance:bytehook:1.0.0'
}
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)
android {
defaultConfig {
ndk {
abiFilters 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64'
}
}
}
If you are using bhook in an SDK project, you may need to avoid packaging libbytehook.so into your AAR, so as not to encounter duplicate libbytehook.so file when packaging the app project.
android {
packagingOptions {
exclude '**/libbytehook.so'
}
}
On the other hand, if you are using bhook in an APP project, you may need to add some options to deal with conflicts caused by duplicate libbytehook.so file.
android {
packagingOptions {
pickFirst '**/libbytehook.so'
}
}
import com.bytedance.android.bytehook.ByteHook;
public class MySdk {
public static synchronized void init() {
ByteHook.init();
}
}
#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);
These three hook functions are used to hook single, partial, and all caller dynamic libraries in the process.
Notice:
BYTEHOOK_CALL_PREV()
macro.BYTEHOOK_POP_STACK()
macro before proxy function returning. In the CPP source file, you can also call BYTEHOOK_STACK_SCOPE()
macro at the beginning of the proxy function instead.dlopen()
and android_dlopen_ext()
internally, so please do not try to hook these two functions. If you want to monitor the loading of ELF, please use bytehook_add_dlopen_callback()
and bytehook_del_dlopen_callback()
.There is a sample app in the bytehook-sample folder you can refer to.