iOS代碼混淆


混淆原理

代碼編譯階段將符號(方法名、屬性名等)替換成隨機生成的字符串

長話短說,直接上步驟。

混淆集成步驟

步驟一、創建shell文件(confuse.sh)並配置相應的運行環境。

  • 在項目根目錄下新建一個文件夾
    image.png
  • 這里取文件夾名稱為CodeObfuscation,如下圖所示
    image.png
  • 在上一步的文件下新建一個shell文件(.sh文件)
    image.png
  • 輸入文件名:confuse.sh,點擊Create按鈕
    image.png
    image.png
  • 給.sh文件添加運行環境
    image.png
  • 添加.sh文件的讀取路徑$PROJECT_DIR/CodeObfuscation/confuse.sh,如下圖
    image.png
  • 給.sh文件添加運行內容(運行代碼)
    將下面的代碼復制粘貼到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
 
#維護數據庫方便日后作排重
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

步驟二、創建func.list文件

image.png

  • 輸入文件名:func.list,點擊Create按鈕
    image.png

步驟三、創建codeObfuscation.h文件

image.png

  • 輸入codeObfuscation.h,點擊Create按鈕
    image.png

步驟四、包含codeObfuscation.h到pch文件中,添加要混淆的方法名或屬性名到func.list

image.png

  • 給func.list文件中添加要混淆的方法名或屬性名
    image.png

步驟五、更改confuse.sh文件的運行權限

  • 打開終端,cd到CodeObfuscation文件夾(不會cd到這個文件夾的可以私聊我)
  • 在終端輸入ls命令並回車查看文件夾內的文件內容如下
    image.png
  • 輸入sudo chmod 777 confuse.sh命令並回車如下圖
    image.png
  • 更改文件權限為可讀可寫可運行,此時需要鍵入開機密碼,mac下不顯示輸入的內容,輸入完畢直接回車即可。
  • 更改confuse.sh文件運行權限完成

步驟六、查看結果

  • 查看codeObfuscation.h文件內容變化,如下圖
    image.png

步驟七、確認結果

如何知道替換成功了呢?我們找到替換的方法名或屬性名,點擊跳轉到定義,會跳轉到codeObfuscation.h中,說明替換成功。
image.png


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM