Objective-C项目代码混淆

编译:就是把千千万万行字符串(也叫代码,或者源文件),变成010101010101(机器码,也叫目标代码);编译过程:预处理-编译-汇编-链接;混淆代码的shell脚本运行在预处理阶段。这里主要参考了网上一些比较流程的做法,对特定前缀的方法名(比如:hsk_function)进行字符串替换。

shell脚本添加的路径为:

Xcode -> Target -> Build Phases -> 添加Run Script


通过class-dump 反编译之后:Appdelegate 效果


程序每次预处理,都就会执行confuse.sh,从.m和.h文件中按照"一定的规则"抽取需要混淆的函数名,全部写到func.list临时文件中,然后再从func.list中逐行提取函数名进行宏定义,宏定义使用随机字符串,然后写到codeObfuscation.h文件中。


===============================================

以下为我的shell脚本代码,是基于HSKConfuse进行修改调整的

===============================================


#!/usr/bin/env bash

########################################

#

#  将代码中以scf_开头的方法名进行混淆处理 (scf:sensitive confused function)

#

########################################

TABLENAME=symbols

SYMBOL_DB_FILE="symbols"

TEM_SYMBOL_FILE="$PROJECT_DIR/***/Supporting-Files/confuse/func.list"#临时文件

CONFUSE_FILE="$PROJECT_DIR/***"

HEAD_FILE="$PROJECT_DIR/***/Supporting-Files/confuse/CodeOfConfuseHeader.h"

export LC_CTYPE=C

#####################################################################################################################

#混淆种子数组,用常规的单词替换随机生成的字符串,避免审核的时候被拒

confuse_sed_1=("touch""get""upload""push""take""make""send""reach""do""is""has""rest""add""check""pick""comment""change")

confuse_sed_2=("Item""Key""Midea""System""Route""Chat""Commis""Info""User""Direction""Moon""Url""Param""Random""Num")

confuse_sed_3=("Home""Page""Function""Method""Location""Count""Topic""Message""Info""Title""Icon""Image""Text""String")

confuse_sed_4=("At""On""In""Before""After""And""Front""Of""With""By""Without""Start""Max""Min""Level""Exist""Out")

confuse_sed_5=("Xing""Hou""Cation""Prj""Direction""Symbol""Name""Value""Fun""Action""Info""Email""Index""Table""Seed")

# 混淆字符串容器

confuse_string_container=()

# 获取随机数组下标,需要传入数组长度作为参数

# eg:$(randomSenArrayIndex 5)

function randomSenArrayIndex(){

max=$1

num=$RANDOM#系统随机数变量

((retnum=num%max+min))

#进行求余数运算即可

echo$retnum

#这里通过echo 打印出来值,然后获得函数的,stdout就可以获得值

#还有一种返回,定义全价变量,然后函数改下内容,外面读取

}

# 传入的字符串是否出现在confuse_string_container中

# eg:(isRandomStringExist "123")

# return: 0:不存在 1:存在

function isRandomStringExist(){

sed=$1

isSedExist=false

for iin${confuse_string_container[@]};do

if[[$i==$sed]];then

isSedExist=true

break

fi

done

echo$isSedExist

}

# 基于混淆种子数组获取随机字符串,不可重复

function randomString(){

# 下标

idx1=$(randomSenArrayIndex${#confuse_sed_1[*]})

idx2=$(randomSenArrayIndex${#confuse_sed_2[*]})

idx3=$(randomSenArrayIndex${#confuse_sed_3[*]})

idx4=$(randomSenArrayIndex${#confuse_sed_4[*]})

idx5=$(randomSenArrayIndex${#confuse_sed_5[*]})

r="${confuse_sed_1[${idx1}]}${confuse_sed_2[${idx2}]}${confuse_sed_3[${idx3}]}${confuse_sed_4[${idx4}]}${confuse_sed_5[${idx5}]}"

if[[$(isRandomStringExist$r)=false]]

then

confuse_string_container=(${confuse_string_container[@]}$r)

echo$r

else

randomString

fi

}

#####################################################################################################################

#创建list临时文件

touch$TEM_SYMBOL_FILE

#取以.m或.h结尾的文件以+号或-号开头的行 |去掉所有+号或-号|用空格代替符号|n个空格跟着<号 替换成 <号|开头不能是IBAction|用空格split字串取第二部分|排序|去重复|删除空行|删掉以init开头的行>写进func.list

grep-h-r-I"^[-+]"$CONFUSE_FILE--include'*.[mh]'|sed"s/[+-]//g"|sed"s/[();,: *\^\/\{]/ /g"|sed"s/[ ]*$TEM_SYMBOL_FILE

#维护数据库方便日后作排重,一下代码来自念茜的微博

function createTable(){

echo"create table $TABLENAME(src text, des text);"| sqlite3$SYMBOL_DB_FILE

}

function insertValue(){

echo"insert into $TABLENAME values('$1' ,'$2');"| sqlite3$SYMBOL_DB_FILE

}

function query(){

echo"select * from $TABLENAME where src='$1';"| sqlite3$SYMBOL_DB_FILE

}

rm-f$SYMBOL_DB_FILE

rm-f$HEAD_FILE

createTable

touch$HEAD_FILE

echo'#ifndef CodeOfConfuseHeader_h

#define CodeOfConfuseHeader_h'>>$HEAD_FILE

echo"//confuse string at `date`">>$HEAD_FILE

cat"$TEM_SYMBOL_FILE"|while read-raline;do

if[[!-z"$line"]];then

ramdom=`randomString`

echo$line$ramdom

insertValue$line$ramdom

echo"#define $line $ramdom">>$HEAD_FILE

fi

done

echo"#endif">>$HEAD_FILE

sqlite3$SYMBOL_DB_FILE.dump

#删除list临时文件

rm-f$TEM_SYMBOL_FILE




致谢大牛们的无私分享:

1、Coder_Hou《iOS代码混淆----自动》

2、念茜《https://blog.csdn.net/yiyaaixuexi/article/details/29201699》

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容