混淆原理
代碼編譯階段將符號(hào)(方法名、屬性名等)替換成隨機(jī)生成的字符串
長(zhǎng)話(huà)短說(shuō)缩筛,直接上步驟爵卒。
混淆集成步驟
步驟一导帝、創(chuàng)建shell文件(confuse.sh
)并配置相應(yīng)的運(yùn)行環(huán)境守谓。
-
在項(xiàng)目根目錄下新建一個(gè)文件夾
新建文件夾
我這里取文件夾名稱(chēng)為CodeObfuscation
,如下圖所示
文件夾
**注意**
這里的文件夾必須在目錄中真實(shí)存在(Xcode9 New Group會(huì)自動(dòng)創(chuàng)建對(duì)應(yīng)的真實(shí)文件夾)您单。 -
在上一步的文件下新建一個(gè)shell文件(.sh文件)
shell文件創(chuàng)建步驟1
輸入文件名:confuse.sh
斋荞,點(diǎn)擊Create按鈕
shell文件創(chuàng)建步驟2
shell文件創(chuàng)建步驟3 -
給.sh文件添加運(yùn)行環(huán)境
運(yùn)行環(huán)境步驟1
添加.sh文件的讀取路徑$PROJECT_DIR/CodeObfuscation/confuse.sh
,如下圖
運(yùn)行環(huán)境步驟2 給.sh文件添加運(yùn)行內(nèi)容(運(yùn)行代碼)
將下面的代碼復(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ù)庫(kù)方便日后作排重
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 "http://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
文件
創(chuàng)建func.list文件步驟1
輸入文件名:
func.list
平酿,點(diǎn)擊Create按鈕創(chuàng)建func.list文件步驟2
創(chuàng)建func.list文件步驟3
步驟三、創(chuàng)建codeObfuscation.h
文件
創(chuàng)建codeObfuscation.h文件步驟1
輸入
codeObfuscation.h
悦陋,點(diǎn)擊Create按鈕創(chuàng)建codeObfuscation.h文件步驟2
創(chuàng)建codeObfuscation.h文件步驟3
步驟四蜈彼、包含codeObfuscation.h
到pch文件中,添加要混淆的方法名或?qū)傩悦?code>func.list
-
包含
codeObfuscation.h
到pch文件中
pch文件配置 -
給
func.list
文件中添加要混淆的方法名或?qū)傩悦?br>需要混淆的方法名
command + R
運(yùn)行項(xiàng)目俺驶,此時(shí)你會(huì)發(fā)現(xiàn)報(bào)錯(cuò)幸逆。
報(bào)錯(cuò)查看
點(diǎn)擊具體錯(cuò)誤后下拉到最下面查看具體內(nèi)容
錯(cuò)誤信息
Permission denied
翻譯成中文就是.sh文件沒(méi)有運(yùn)行權(quán)限
如何更改confuse.sh
文件的運(yùn)行權(quán)限呢,如下步驟暮现。
- 打開(kāi)終端秉颗,cd到
CodeObfuscation
文件夾(不會(huì)cd到這個(gè)文件夾的可以私聊我) - 在終端輸入
ls
命令并回車(chē)查看文件夾內(nèi)的文件內(nèi)容如下
CodeObfuscation文件夾內(nèi)容 - 輸入
sudo chmod 777 confuse.sh
命令并回車(chē)如下圖
更改文件權(quán)限為可讀可寫(xiě)可運(yùn)行
此時(shí)需要鍵入開(kāi)機(jī)密碼,mac下不顯示輸入的內(nèi)容送矩,輸入完畢直接回車(chē)即可。 - 更改
confuse.sh
文件運(yùn)行權(quán)限完成
重新回到xcode項(xiàng)目哪替,command + R
運(yùn)行項(xiàng)目栋荸,運(yùn)行成功。
步驟五凭舶、查看結(jié)果
查看codeObfuscation.h
文件內(nèi)容變化晌块,如下圖
替換結(jié)果
步驟六、確認(rèn)結(jié)果
如何知道替換成功了呢帅霜?我們找到替換的方法名或?qū)傩悦冶常c(diǎn)擊跳轉(zhuǎn)到定義,會(huì)跳轉(zhuǎn)到codeObfuscation.h
中身冀,說(shuō)明替換成功钝尸。
查看替換結(jié)果
功夫不負(fù)有心人,祝大家工作順利