混淆原理
代碼編譯階段將符號(方法名、屬性名等)替換成隨機生成的字符串
長話短說,,直接上步驟,。
混淆集成步驟
步驟一,、創(chuàng)建shell文件(confuse.sh)并配置相應(yīng)的運行環(huán)境。
- 在項目根目錄下新建一個文件夾
- 這里取文件夾名稱為CodeObfuscation,,如下圖所示
- 在上一步的文件下新建一個shell文件(.sh文件)
- 輸入文件名:confuse.sh,,點擊Create按鈕
- 給.sh文件添加運行環(huán)境
- 添加.sh文件的讀取路徑$PROJECT_DIR/CodeObfuscation/confuse.sh,如下圖
- 給.sh文件添加運行內(nèi)容(運行代碼)
將下面的代碼復(fù)制粘貼到confuse.sh文件中
TABLENAME=symbols
SYMBOL_DB_FILE="$PROJECT_DIR/CodeObfuscation/symbols"
STRING_SYMBOL_FILE="$PROJECT_DIR/CodeObfuscation/func.list"
HEAD_FILE="$PROJECT_DIR/CodeObfuscation/codeObfuscation.h"
export LC_CTYPE=C
#維護(hù)數(shù)據(jù)庫方便日后作排重
createTable(){
echo "create table $TABLENAME(src text, des text);" | sqlite3 $SYMBOL_DB_FILE
}
insertValue(){
echo "insert into $TABLENAME values('$1' ,'$2');" | sqlite3 $SYMBOL_DB_FILE
}
query(){
echo "select * from $TABLENAME where src='$1';" | sqlite3 $SYMBOL_DB_FILE
}
ramdomString(){
openssl rand -base64 64 | tr -cd 'a-zA-Z' |head -c 16
}
rm -f $SYMBOL_DB_FILE
rm -f $HEAD_FILE
createTable
touch $HEAD_FILE
echo '#ifndef Demo_codeObfuscation_h
#define Demo_codeObfuscation_h' >> $HEAD_FILE
echo "//confuse string at `date`" >> $HEAD_FILE
cat "$STRING_SYMBOL_FILE" | while read -ra line; do
if [[ ! -z "$line" ]]; then
ramdom=`ramdomString`
echo $line $ramdom
insertValue $line $ramdom
echo "#define $line $ramdom" >> $HEAD_FILE
fi
done
echo "#endif" >> $HEAD_FILE
sqlite3 $SYMBOL_DB_FILE .dump
步驟二,、創(chuàng)建func.list文件
- 輸入文件名:func.list,點擊Create按鈕
步驟三,、創(chuàng)建codeObfuscation.h文件
- 輸入codeObfuscation.h,,點擊Create按鈕
步驟四,、包含codeObfuscation.h到pch文件中,添加要混淆的方法名或?qū)傩悦絝unc.list
- 給func.list文件中添加要混淆的方法名或?qū)傩悦?br>
步驟五、更改confuse.sh文件的運行權(quán)限
- 打開終端,,cd到CodeObfuscation文件夾(不會cd到這個文件夾的可以私聊我)
- 在終端輸入ls命令并回車查看文件夾內(nèi)的文件內(nèi)容如下
- 輸入sudo chmod 777 confuse.sh命令并回車如下圖
- 更改文件權(quán)限為可讀可寫可運行,此時需要鍵入開機密碼,,mac下不顯示輸入的內(nèi)容,輸入完畢直接回車即可,。
- 更改confuse.sh文件運行權(quán)限完成
步驟六、查看結(jié)果
- 查看codeObfuscation.h文件內(nèi)容變化,,如下圖
步驟七、確認(rèn)結(jié)果
如何知道替換成功了呢,?我們找到替換的方法名或?qū)傩悦?,點擊跳轉(zhuǎn)到定義,會跳轉(zhuǎn)到codeObfuscation.h中,,說明替換成功,。
|