代码混淆

LLVM编译过程:

预处理,词法分析,token,语法分析,AST,代码生成,LLVM IR,优化,生成,汇编代码,link,目标文件。

Clang -E 项目名/main.m指令查看预处理preprocess结果
clang -fmodules -E -Xclang -dump-tokens 项目名/main.m 词法分析(输出Token流)
clang -fmodules -fsyntax-only -Xclang -ast-dump 项目名/main.m,语法分析,抽象语法树

中间代码IR三种表现形式:

1:文本text型
2:Memory
3:bitcode二进制格式

在执行clang -c -emit-llvm main.m指令时如果爆fatal error: 'UIKit/UIKit.h' file not found可以通过下边指令去处理生成.cpp文件(c++文件)

①cd /Users/amy/Desktop/项目名/项目文件夹
②clang -x objective-c -rewrite-objc -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk ViewController.m

此番操作之后,会在对应的项目/项目文件夹里多出来一个.cpp文件。

通过Libclang和Libtooling可以改变 clang 生成代码的方式,增加更强的类型检查,或者按照自己的定义进行代码的检查分析等等。

那么Libclang和Libtooling的区别是什么?

Libclang:基于c,如果只需要语法分析或者做代码补全,优选。
Libtooling : 基于C++,比Libclang强大全面的AST(抽象语法树)解析和控制能力。但版本兼容性差于Libclang。整体是提供了完整的参数解析方案,可很方便的构建一个独立的命令行工具。

混淆方法一:

脚本实现:

图片.png

创建.sh,.list,.h,文件以及.pch文件。

.sh文件放入的脚本

TABLENAME=symbols
SYMBOL_DB_FILE="$PROJECT_DIR/CodeObfuscation/symbols"
STRING_SYMBOL_FILE="$PROJECT_DIR/CodeObfuscation/func.list"
HEAD_FILE="$PROJECT_DIR/CodeObfuscation/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

.list放入要混淆的原方法名
.pch导入自行添加的.h文件

如果.pch文件不能捕获.h文件,通过Build Settings – Prefix Header, 修改pch路径为$(PROJECT_DIR)/HX3Demo/HX3-Prefix.pch(HX3Demo/HX3-Prefix.pch替换成自己对应文件名)

注释:自己在xcode11.6的版本下操作的过程中,发现不添加$(PROJECT_DIR)/,在 Build Phases->Run Script里配置完$PROJECT_DIR/CodeObfuscation/confuse.sh情况下,.pch文件是捕获不到.h文件的.

该方法只能对.m和.h成对存在的类进行混淆。对于只有.h文件的静态库没法进行混淆。

混淆方法二:

控制流实现:

在GitHub下载对应的pkg.安装
https://github.com/HikariObfuscator/Hikari/releases

使用:
1:Xcode -> Toolchains -> Hikari将混淆工具和项目关联
2:将所有与要运行的 target 相关的 target(包括pod进来的库)Enable Index-While-Building的值改为 NO
3:Optimization Level 的值设置为 None[-O0]
4:在 Build Settings -> Other C Flags中加入混淆标记

 -mllvm -enable-bcfobf         启用伪控制流
 -mllvm -enable-cffobf         启用控制流平坦化
 -mllvm -enable-splitobf     启用基本块分割
 -mllvm -enable-subobf         启用指令替换
 -mllvm -enable-acdobf         启用反class-dump
 -mllvm -enable-indibran     启用基于寄存器的相对跳转,配合其他加固可以彻底破坏IDA/Hopper的伪代码(俗称F5)
 -mllvm -enable-strcry         启用字符串加密
 -mllvm -enable-funcwra     启用函数封装
 -mllvm -enable-allobf         依次性启用上述所有标记

5:编译即可。

运行成功后将 Products 中的二进制文件拖入到 hopper 中查看混淆前后的结果如下:


截屏2020-08-27 下午7.53.50.png

个人觉得值的参考学习的链接:
https://blog.csdn.net/Deft_MKJing/article/details/84943381
https://zhuanlan.zhihu.com/p/53396745
//www.greatytc.com/p/ccfe5623483d

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,997评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,603评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,359评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,309评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,346评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,258评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,122评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,970评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,403评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,596评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,769评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,464评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,075评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,705评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,848评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,831评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,678评论 2 354