iOS-最新代码混淆

代码混淆其实就是字符串替换,目前有二种方法可以实现,一个是#define,一个是利用tops,本文主要是讲解#define方式替换步骤。

一:配置confuse.shfunc.list文件

1.打开终端 cd到你的项目根目录
2.分别创建2个文件:touch confuse.shtouch func.list

[1]

3.将文件加入到你的项目

2

3

4.添加Run Script

4

5.设置脚本相对路径 $PROJECT_DIR/confuse.sh

5

6.编写 脚本文件 内容

#!/usr/bin/env bash

TABLENAME=symbols
SYMBOL_DB_FILE="symbols"
STRING_SYMBOL_FILE="func.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 "//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

将脚本内容复制到 confuse.sh文件里

截屏2020-08-28 16.46.56.png

7.设置脚本权限,先cd到项目,然后输入chmod 755 confuse.sh

7

8.运行项目,会自动生成一个codeObfuscation.h文件,拉入工程目录

8

9.在func.list里添加要混淆的方法名,属性名,在运行会自动在codeObfuscation.h里生成随机方法名称

10
二:注意事项

1.导入codeObfuscation.h前先设置权限(第7步)
2.确保func.list文件与confuse.sh文件在同一个文件夹里面

参考文章:念茜 iOS安全攻防(二十三):Objective-C代码混淆

你可能感兴趣的:(iOS-最新代码混淆)