Cydia Substrate入門---hook native代碼

主要介紹如何使用Cydia Substrate去hook native代碼薯鳍。本文是抄襲的,當作個人筆記挨措。
1.建立project挖滤,選擇No Activity;
2.在app-main下建立jni文件夾运嗜;
3.將cydia_substrate-r2下的substrate.h壶辜、libsubstrate.so和libsubstrate-dvm.so三個文件放入jni目錄中,這里要注意根據架構的不同担租,選擇x86或ARM目錄下的libsubstrate.so和libsubstrate-dvm.so
4.同樣在jni目錄下建立test.cy.cpp(一定要記得帶‘cy’)和Android.mk兩個文件砸民;
5.test.cy.cpp內容:

#include "substrate.h"
#include <dlfcn.h>
#include <android/log.h>
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "HookGetSpeed", __VA_ARGS__)
#define LIB "/data/app-lib/com.shandagames.bop-1/libShellClient.so"

MSConfig(MSFilterExecutable,"/system/bin/app_process")
//MSConfig(MSFilterLibrary, "libdvm.so");

int (* old_getSpeed)(void);
int  new_getSpeed(void * CCharacter){
    LOGD("getSpeed %d",(&CCharacter + 28));
    return 1;
}


int (* old_SpeedUp)(int);
int new_SpeedUp(int a2){
    LOGD("a2 : %d",a2);
    return old_SpeedUp(a2);
}

int (* old_SetScale)(int,float);
int new_SetScale(int result,float a2){
    LOGD("result : %d",result);
    LOGD("a2 : %d",a2);
    *(float *)(result + 1136) = a2;
    return result;
}


//通過so庫的絕對路徑和函數名,找到其函數的映射地址
void* lookup_symbol(char* libraryname,char* symbolname)
{
    //獲取so庫的句柄
    void *handle = dlopen(libraryname, RTLD_GLOBAL | RTLD_NOW);
    if (handle != NULL){
        LOGD("dlopen success");
        void * symbol = dlsym(handle, symbolname);
        if (symbol != NULL){

            LOGD("dlsym %s success",symbolname);
            return symbol;
        }else{
            LOGD("dl error: %s", dlerror());
            return NULL;
        }
    }else{
        LOGD("dlopen %s faile",libraryname);
        return NULL;
    }
}

MSInitialize
{
    //獲取hook函數的地址,最好不要用下面MS提供的方法
    void * symbol = lookup_symbol(LIB,"_ZN16CGameSceneClient8SetScaleEf");
    if(symbol != NULL){
        LOGD("symbol address is 0x%08X",&symbol);
        //這里將舊函數的入口(參數一)指向hello(參數三),然后執(zhí)行新函數(參數二)
        MSHookFunction(symbol, (void *)&new_SetScale, (void **)&old_SetScale);
        LOGD("MSHookFunction finish");
    }
}

使用官方提供的方法有時候不能獲取到symbol岭参。
6.Android.mk內容

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)
LOCAL_MODULE:= substrate-dvm
LOCAL_SRC_FILES := libsubstrate-dvm.so
include $(PREBUILT_SHARED_LIBRARY)

include $(CLEAR_VARS)
LOCAL_MODULE:= substrate
LOCAL_SRC_FILES := libsubstrate.so
include $(PREBUILT_SHARED_LIBRARY)


include $(CLEAR_VARS)
LOCAL_MODULE    := test.cy #生成的模塊名
LOCAL_SRC_FILES := test.cy.cpp #源文件名
LOCAL_LDLIBS := -llog
LOCAL_LDLIBS += -L$(LOCAL_PATH) -lsubstrate-dvm -lsubstrate
include $(BUILD_SHARED_LIBRARY)

7.修改project下面的local.properties文件反惕,末尾增加ndk路徑
8.修改gradle.properties文件,末尾增加:

android.useDeprecatedNdk=true

9.修改app下的build.gradle文件
defaultConfig{}中增加ndk設置

ndk{
            moduleName "test.cy"
            ldLibs "substrate"
            ldLibs "substrate-dvm"
        }

因為要手動ndk-build演侯,需要在android{}中增加jni和jniLibs路徑說明:

sourceSets {
    main {
        jni.srcDirs = []
        jniLibs.srcDirs = ['src/main/libs']

}
}

jni.srcDirs = [] 表示禁止as自動ndk編譯姿染,采用手動ndk-build

jniLibs.srcDirs = [‘src/main/libs’] 表示經過ndk-build編譯后的so路徑

10.OK,接下來手動ndk-build吧秒际,teminal下悬赏,進入到app/src/main/jni目錄,因為是x86平臺的編譯娄徊,所以輸入時需要帶參數:
D:\MyCandy\app\src\main\jni>ndk-build APP_ABI=”x86″

11.模擬器安裝好com.saurik.substrate_0.9.4010.apk闽颇,運行,并給予Root權限寄锐;
注意在AndroidManifest.xml中添加權限:<uses-permission android:name=”cydia.permission.SUBSTRATE”/>

https://koz.io/android-substrate-c-hooking/
http://mybeibei.net/1051.html
http://www.cydiasubstrate.com/id/73e45fe5-4525-4de7-ac14-6016652cc1b8/
https://blog.csdn.net/jk38687587/article/details/51498062

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末兵多,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子橄仆,更是在濱河造成了極大的恐慌剩膘,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盆顾,死亡現場離奇詭異怠褐,居然都是意外死亡,警方通過查閱死者的電腦和手機椎扬,發(fā)現死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進店門惫搏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蚕涤,你說我怎么就攤上這事筐赔。” “怎么了揖铜?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵茴丰,是天一觀的道長。 經常有香客問我天吓,道長贿肩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任龄寞,我火速辦了婚禮汰规,結果婚禮上,老公的妹妹穿的比我還像新娘物邑。我一直安慰自己溜哮,他們只是感情好滔金,可當我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著茂嗓,像睡著了一般餐茵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上述吸,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天忿族,我揣著相機與錄音,去河邊找鬼蝌矛。 笑死道批,一個胖子當著我的面吹牛,可吹牛的內容都是我干的朴读。 我是一名探鬼主播屹徘,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼衅金!你這毒婦竟也來了?” 一聲冷哼從身側響起簿煌,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤氮唯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后姨伟,有當地人在樹林里發(fā)現了一具尸體惩琉,經...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年夺荒,在試婚紗的時候發(fā)現自己被綠了瞒渠。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡技扼,死狀恐怖伍玖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情剿吻,我是刑警寧澤窍箍,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站丽旅,受9級特大地震影響椰棘,放射性物質發(fā)生泄漏。R本人自食惡果不足惜榄笙,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一邪狞、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧茅撞,春花似錦帆卓、人聲如沸巨朦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽罪郊。三九已至,卻和暖如春尚洽,著一層夾襖步出監(jiān)牢的瞬間悔橄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工腺毫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留癣疟,地道東北人。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓潮酒,卻偏偏與公主長得像睛挚,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子急黎,可洞房花燭夜當晚...
    茶點故事閱讀 44,927評論 2 355

推薦閱讀更多精彩內容