iOS自动代码混淆

前言:

因为公司要做一个金融类型的app,安全措施是必不可少的,代码混淆便是其中一种。(这里只对方法名进行混淆)

一、什么是代码混淆

简单来说,就是别人通过class-dump反编译你的应用后,不会显示你自定义的方法名(系统方法名除外),增加其对你应用的理解难度。注意:这样并不能阻止别人反编译你的应用。

二、如何自动进行代码混淆

以下内容均取自
iOS代码混淆----自动 感谢大神的分享

步骤
1. 创建一个新的工程,打开终端,cd 到你的项目目录中

image.png

分别创建 confuse.shfunc.list这两个文件

image.png

之后还要创建 PCH和一个 Confuse.h文件

iOS自动代码混淆_第1张图片
image.png

将这两个文件添加到项目中,都是空文件,下面开始往里面加东西。

2.confuse.sh文件中添加以下代码

#!/usr/bin/env bash

TABLENAME=symbols
SYMBOL_DB_FILE="symbols"
STRING_SYMBOL_FILE="$PROJECT_DIR/CodeConfuse/confuse/func.list"

CONFUSE_FILE="$PROJECT_DIR/CodeConfuse"

HEAD_FILE="$PROJECT_DIR/CodeConfuse/confuse/CodeConfuse.h"

export LC_CTYPE=C

#取以.m或.h结尾的文件以+号或-号开头的行 |去掉所有+号或-号|用空格代替符号|n个空格跟着<号 替换成 <号|开头不能是IBAction|用空格split字串取第二部分|排序|去重复|删除空行|删掉以init开头的行>写进func.list
grep -h -r -I  "^[-+]" $CONFUSE_FILE  --include '*.[mh]' |sed "s/[+-]//g"|sed "s/[();,: *\^\/\{]/ /g"|sed "s/[ ]*$STRING_SYMBOL_FILE


#维护数据库方便日后作排重,以下代码来自念茜的微博
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 CodeConfuse_h
#define CodeConfuse' >> $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


对代码中的一些地方进行说明

iOS自动代码混淆_第2张图片
image.png

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

iOS自动代码混淆_第3张图片
image.png
image.png

3. 首先,你要学会class-dump,安装class-dump
class-dump 下载安装包,将下面的文件复制到/usr/local/bin目录下

iOS自动代码混淆_第4张图片
image.png

然后再终端输入 class-dump,显示下面的界面就说明安装正确
iOS自动代码混淆_第5张图片
image.png

在viewController写入一些方法,前缀带 nhb_和不带前缀的方法,方便 class-dump后进行比较
iOS自动代码混淆_第6张图片
image.png

运行程序,可能会报错,有两种情况:

No such file or directory 这种是因为你文件的路径没有找到,通过在项目中New Group创建文件夹在Show in Finder中是找不到这个文件的,要在项目的Show in Finder中创建文件夹,然后拖到项目中

Permission Denied sh文件权限被拒绝,解决办法:打开终端,cdconfuse.sh文件夹目录下,输入命令 chomd 755 confuse.sh

运行程序,然后找出程序的执行文件
Products -> Show in Finder -->显示包内容

iOS自动代码混淆_第7张图片
image.png

image.png

找到这个文件, CodeConfuse

image.png

此时我们就可以在终端输入命令
class-dump -H CodeConfuse的文件路径 -o 导出的.h文件存放文件夹路径

image.png

执行完成之后我们可以在文件夹中找到dump的.h文件,右面是class-dump后的.h文件,结果很明显,你通过class-dump后的方法名变成毫无意义的字符串,这样给别人反编译我们的应用增加了很大的难度。

iOS自动代码混淆_第8张图片
image.png

在文章的最开始,我就说了,这种方法只是增加编译后的阅读难度,毕竟反编译有很多办法,没有绝对的安全!

你可能感兴趣的:(iOS自动代码混淆)