文章目录
- 一、混淆的原理
- 二、实现混淆
- 1. 创建文件
- 2. 将文件拖导入目录中
- 3. 将以下脚本拷贝到刚新建的confuse.sh文件中
- 4. 修改文件权限
- 5. 修改项目配置
- 6. 添加需要混淆的方法名
- 7. 配置PCH文件
- 8. 运行效果
一、混淆的原理
这里使用的混淆的原理是,用一串随机生成的字符串来替换相应的函数名和变量名
二、实现混淆
1. 创建文件
在相应的项目工程下新建一个confuse.sh 和 func.list文件
$ cd /Users/xxx/Desktop/ xxx
$ touch confuse.sh
$ touch func.list
2. 将文件拖导入目录中
3. 将以下脚本拷贝到刚新建的confuse.sh文件中
脚本源头来源
#!/usr/bin/env bash
# 这是Shel脚本,如果不懂shell,自行修炼: http://www.runoob.com/linux/linux-shell.btml
# 以下使用sqlite了进行增加数据,如果不了解sqlite了命令,自行修炼: http://www.runoob.com/salite/sqlite-tutorial.html# 数据表名
TABLENAME=symbols# 数据库名
SYMBOL_DB_FILE="symbols"# 要被替换的方法列表文件
STRING_SYMBOL_FILE-"$PROJECT_DIR/func.list"# 被替换后的宏定义在此文件里
HEAD_FILE-"$PROJECT_DIR/$PROJECT_NAME/CodeObfuscation.h"export LC_CTYPE=C# 维护数据库方便日后做bug排查
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
}# 生成随机16位名称
ramdomString()
{openssl rand -base64 64 | tr -cd 'a-zA-Z' | head -c 16
}# 删除旧数据库文件
rm -f $SYMBOL_DB_FILE# 删除就宏定义文件
rm -f $HEAD_FILE# 创建数据表
createTable# touch命令创建空文件,根据指定的路径
touch $HEAD_FILE
echo '#ifndef Demo_codeObfuscation_h
#define CodeObfuscation_h' >> $HEAD_FILE
echo "//confuse string at `date`" >> $HEAD_FILE
# 使用cat将方法列表文件里的内容全部读取出来,形成数组,然后逐行读取。并进行替换
cat "$STRING_SYMBOL_FILE" | while read -ra line;
doif [[ ! -z "$line" ]];thenramdom=`ramdomString`echo $line $ramdom# 将生成的随机字符串插入到表格中insertValue $line $ramdom# 將生成的宇符串写入到宏定义文件中,变量是$HEAD_FILEecho "#define $line $ramdom" >> $HEAD_FILEfi
doneecho "#endif" >> $HEAD_FILEsqlite3 $SYMBOL_DB_FILE .dump
4. 修改文件权限
$ chmod 755 confuse.sh
5. 修改项目配置
新增Run Script 添加
$PROJECT_DIR/confuse.sh
6. 添加需要混淆的方法名
打开func.list文件,在文件内输入需要进行方法名混淆的方法名
viewDidLoad
7. 配置PCH文件
- 新建PCH文件
- 在工程的TARGETS里边Building Setting中搜索Prefix Header,添加文件
$(SRCROOT)/项目名称/xxx.pch
- 在PCH中引入头文件
#import "CodeObfuscation.h"
8. 运行效果
command+B运行