OC代码简单的混淆-方法变量名字符串替换

2014-12-14 22:44:27

需要一个function.list文件 — 用于存放你想混淆的方法名,类名或变量名;

需要一个脚本confuse.sh文件 — 用于逐一define在function.list中的方法名,类名或变量名为16位随机的字符串,并且生成一个.h头文件,包含的是各种define;

原理:使用上述.h导入工程中,使其预编译执行:将.h头文件import在pch文件中,然后编译运行。

 

1. 需要一个脚本confuse.sh

用下面代码生成一个confuse.sh



#!/usr/bin/env bash  
  
TABLENAME=symbols  
SYMBOL_DB_FILE="symbols"  
STRING_SYMBOL_FILE="function.list"  
HEAD_FILE="$PROJECT_DIR/$PROJECT_NAME/confuse.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 confuse_codeObfuscation_h
#define confuse_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



 

2.需要一个function.list,里面存放敏感的需要进行字符串替换的方法名或者变量名

例如你需要将下面这两个方法进行字符串替换



- (NSString *)pswFromData:(NSData *)data;
- (NSString *)accountFromData:(NSData *)data;



在function.list中写两条



pswFromData
accountFromData



 

3.运行脚本,生成.h文件

  • 3.1 将confuse.sh和function.list放置xcode工程目录下:

 

ios 字符串range改变颜色 ios字符串混淆_xcode

3.2 添加运行脚本:

ios 字符串range改变颜色 ios字符串混淆_sqlite_02

  • 3.3  运行工程:

Run之后,在工程的根目录下可以看到生成的confuse.h头文件

ios 字符串range改变颜色 ios字符串混淆_变量名_03

 

4.导入.h到工程,在pch中包含该头文件,达到预编译的目的

ios 字符串range改变颜色 ios字符串混淆_数据库_04

 

导入confuse.h之后,在pch中包含它:

ios 字符串range改变颜色 ios字符串混淆_变量名_05

 

5.运行工程,查看效果

查看对应的方法名,类名或变量名在工程中有没有变成宏的颜色,有的话说明混淆成功。

 

OK,OC中这种简单的混淆就搞定了,快试一试吧~


 

注意:用Xcode 6+新建的工程中不再自带一个XX-Prefix.pch,所以如果工程中没有pch,可以自行创建一个,方法如下:

1.在工程中按下图进行New File 

 

ios 字符串range改变颜色 ios字符串混淆_ios 字符串range改变颜色_06

2.选择Other中的PCH点击Next

ios 字符串range改变颜色 ios字符串混淆_sqlite_07

 

3. 设置pch的文件名,建议命名:工程名-PrefixHeader.pch (这里默认起名为PrefixHeader.pch)

Group在Supporting Files下,点击Create

 

ios 字符串range改变颜色 ios字符串混淆_xcode_08

4. 生成的PrefixHeader.pch在工程的虚拟目录Supporting Files下(对应在工程的根目录下)

 

ios 字符串range改变颜色 ios字符串混淆_变量名_09

5. 设置pch文件的路径

   在Build Settings内的Apple LLVM 6.0 – Language栏下,更改Prefix Header的路径为 $(SRCROOT)/你的工程名/你的pch文件名.pch

   你可以在Build Settings的搜索框中输入:Prefix找到该选项。

   至此pch文件创建成功。

ios 字符串range改变颜色 ios字符串混淆_ios 字符串range改变颜色_10