iOS 安全 之 方法混淆

APP安全(安全防護(hù)篇)

 對(duì)APP的安全防護(hù)主要是對(duì)程序進(jìn)行加密,其中加密有五個(gè)方向

  1.URL編碼加密 對(duì)程序中出現(xiàn)的URL進(jìn)行編碼加密,防止URL被靜態(tài)分析。
  2.本地?cái)?shù)據(jù)加密 對(duì)NSUserDefaults,sqlite存儲(chǔ)文件數(shù)據(jù)加密,保護(hù)帳號(hào)和關(guān)鍵信息。
  3.網(wǎng)絡(luò)傳輸數(shù)據(jù)加密 對(duì)客戶端傳輸數(shù)據(jù)提供加密方案,有效防止通過網(wǎng)絡(luò)接口的攔截獲取。
  4.方法體,方法名高級(jí)混淆 對(duì)應(yīng)用程序的方法名和方法體進(jìn)行混淆,保證源碼被逆向后無(wú)法解析代碼。
  5.程序結(jié)構(gòu)混排加密 對(duì)應(yīng)用程序邏輯結(jié)構(gòu)進(jìn)行打亂混排,保證源碼可讀性降到最低。

今天重點(diǎn)說(shuō)一下 方法體 方法名的混淆。
首先看效果吧:

84B10B95-A4CE-4305-BD59-37A671BBF513.png

#使用hopper disassembler 反編譯iPA之后不能得到相應(yīng)的方法調(diào)用信息

FE50C8B4-A19A-4279-A01E-0D4F64870724.png

那么如何做到呢?
創(chuàng)建shell腳本:

TABLENAME=symbols
SYMBOL_DB_FILE="symbols"
STRING_SYMBOL_FILE="fun.list"
HEAD_FILE="$PROJECT_DIR/$PROJECT_NAME/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 "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

第二 聲明要替換的方法名列表

      在上邊腳本中提到了 STRING_SYMBOL_FILE="fun.list",意思就是運(yùn)行腳本的時(shí)候會(huì)到這個(gè)文件去讀取需要替換的方法名,重新寫入符號(hào)表中。
      nameAction
      refreshAction

第三步: 生成對(duì)應(yīng)的轉(zhuǎn)義之后的無(wú)序字符串

47A87D69-4262-48E4-957F-5AD91014932F.png

具體demo 很早之前寫的 ,鏈接 Blank_佐毅

另外
招聘UI交互設(shè)計(jì)師啦!
招聘UI交互設(shè)計(jì)師啦!
招聘UI交互設(shè)計(jì)師啦!
招聘UI交互設(shè)計(jì)師啦!
招聘UI交互設(shè)計(jì)師啦!

嗯,重要的事情說(shuō)五遍。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容