继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

使用classdump和自定义脚本实现iOS代码混淆方法

慕仙7434376
关注TA
已关注
手记 85
粉丝 1
获赞 10

我们可以用classdump对原程序进行 dump,我们可以看到所有.h 文件全暴露了(如下图)

点击HWAccount.h后,里面的函数名,属性名也一样清清楚楚:

这样就相当于在裸奔,这时候我们就需要用到代码混淆了。除了手动脚本方法,开发者也可以使用专业工具如IpaGuard进行IPA文件混淆,它无需源码即可对代码和资源进行混淆加密,支持多种开发平台,有效增加反编译难度。简单点讲,就是把你的这些个用户名和函数名弄得没有可读性,比如你的用户名的变量名定义为 userName,那你自己用肯定是正常的,如果黑客们 dump 出来的这个变量名会变成 abcd 或 1234 ,这样他也就不清楚你这是用来干吗的了。

第一、在工程项目路径中建立一个confuse.sh、一个func.list文件

1、先打开终端,然后 cd 到你的项目工程路径下:

$ cd /Users/yoowei/Desktop/学习资料(hello)/重要资料/代码混淆实验/yoowei

2、创建两个文件,一个 confuse.sh,一个 func.list

$ touch confuse.sh

$ touch func.list

3、这时候我们打开这个工程文件夹,可以看到,这两个文件已经创建好了:

4、打开工程,把刚才创建的两个文件加进去,右键你的项目蓝色标志,然后选择 Add Files to yoowei:

5、点击 confuse.sh ,发现还是空白的,需要添加如下脚本:

#!/usr/bin/env bash

TABLENAME=symbols

SYMBOL_DB_FILE=“symbols”

STRING_SYMBOL_FILE=“func.list”

HEAD_FILE=“PROJECTDIR/PROJECT_NAME/codeObfuscation.h”

export LC_CTYPE=C

#维护数据库方便日后作排重

createTable()

{

echo “create table TABLENAME(srctext,destext);”|sqlite3SYMBOL_DB_FILE

}

insertValue()

{

echo “insert into TABLENAMEvalues(′1’ ,'2′);”|sqlite3SYMBOL_DB_FILE

}

query()

{

echo “select * from TABLENAMEwheresrc=′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 lineramdom

insertValue lineramdom

echo “#define lineramdom” >> $HEAD_FILE

fi

done

echo “#endif” >> $HEAD_FILE

sqlite3 $SYMBOL_DB_FILE .dump

6、在 .pch 文件中引用文件

一般的时候,在添加后会报错,因为脚本文件还没有被引用

第二、配置 Build Phase

1、添加 Run Script

2、配置Run Script

$PROJECT_DIR/confuse.sh

3、开启权限

然后再回到终端,同样先 cd 到工程目录下,接着我们要打开刚才 .sh 这个脚本文件的运行权限,因为默认是没有这个权限的,在终端输入以下指令:

$ chmod 755 confuse.sh

回车,回到我们的工程,先 command + b 编译一下工程,然后再把我们刚刚注释掉的那句打开( .pch文件报错的)

再次 command + b 编译,问题解决,编译成功。

第三、在 func.list 文件里,写入待混淆的函数名

需要混淆的属性跟函数名,在 fun.list 就这么列出来就好了:

大功告成!现在 command + b 运行一下,然后在哪里看结果呢,请看这里:

在来到HWAccount.h 发现:

最后,我发现整个项目中所有用到name的地方都被替换成了宏,反而跑不起来了,这个需要研究解决?

鉴于此,我们在做代码混淆的时候,可能要一个一个的弄,别出错了。或者不要在pch文件引用也是一个解决方案 。总之要十分小心。

下面用class-dump弄过之后的结果和前文对照一下:还是有点作用的。

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP