iOS App Hack过程

    首先,你需要有一台越狱的iOS手机,这样你才能获得root权限,才能为所欲为;需要一台Mac机器,方便你远程操作。接着你就需要安装一打的软件了,Mac上需安装:class-dump(导出头文件),Reveal(分析UI),Hopper Disassembler(静态汇编代码分析),charles(网络分析),iFunBox(手机文件分析),usbmuxd(通过usb转发网络数据);手机上需在Cydia商店中安装:OpenSSH,Reveal Loader(和Mac上Reveal配合使用),vim, python等。

    在你手机上安装完想Hack的App后,就可以开工了。

0,说明

    下面所有的"#"步骤都是在SSH中操作的,"$"步骤在Mac上操作。

一,使用dumpdecrypted获得头文件

    从github上下载,make编译,将生成的dumpdecrypted.dylib拷贝到手机/var/root目录下。利用Mac上iFunBox获得App的路径,然后将dumpdecrypted.dylib文件拷贝到App的Document目录下。

#cd Document

#DYLD_INSERT_LIBRARIES=dumpdecrypted.dylib App可执行文件路径,

会在当前Document目录下生成xxx.decrypted文件,即该App未加密的可执行文件。将该decrypted文件拷到本机,用命令

$class-dump --arch armv7/arm64 -H xxx.decrypted -o 头文件路径,

生成所有头文件。由于decrypted文件为FAT格式,它实际上包了两种格式的可执行文件,armv7和arm64,需要你根据自己的手机型号选择相应的格式(我用的iPhone4为armv7格式)。获得头文件以后,就可以用Xcode新建一个Project,将所有头文件都导入Project中,方便查询。

二,使用Hopper Disassembler v3进行静态分析(或者使用IDA)

    选择File -> Read Executable to Assemble打开xxx.decrypted文件,选择FAT,armv7或aarch64格式,它就开始自动帮你解析arm格式的汇编语言。在最左边搜索框中搜索你感兴趣的类和方法,可以结合Xcode中的头文件来使用。下面说说它最强大的功能了,就是可以帮你生成类oc的伪代码。选择你关心的函数,再点选右上角if(b) f(x):图标,立刻世界就简单了很多。

三,使用Reveal分析UI及相关的类

    如果分析App的话,光看头文件还是一头雾水的,如果使用Reveal来分析UI使用的View类和相应的Controller类,那世界又简单了很多。先打开Mac上Reveal软件,再在手机上"设置" -> Reveal -> Enabled Applications中选中你想分析的App,再打开App,稍等片刻,最后在Reveal中选中发现的App就可以了。如果一直没有在Reveal中发现App,要确保手机和Mac在同一网络中,重启几次App看看。

四,使用charles分析网络通信

    现在几乎所有的App都是C/S模式的,本地是客户端,通过网络访问Web Server端。所以想真正了解App的行为,分析网络通信是很有必要的。而且绝大多数的App(除了知名的App如微信外)网络封包没有加密,很容易分析通信过程。

    手机端只需在Http Proxy中设置Mac机IP地址和8888端口即可(charles默认端口为8888)。Mac端启用charles,选择接受手机端的连接。

五,使用lldb动态调试

    要分析App的关键细节,就非需要动态调试不可了。可以用GDB来动态调试,但听说它不太稳定(听说而已,没有亲见),所以还是用debugserver+lldb的方式来调试了。debugserver和lldb均为Xcode自带软件,将debugserver拷贝到手机上,运行

#debugserver *:1234 -a “进程名”

Mac上因为直接使用网络进行调试速度太慢,使用usbmuxd用usb接口进行网络包中转

$cd usbmuxd-1.0.8/python-client

$./tcprelay.py 1234:1234

再启用lldb

$lldb

(lldb)process connect connect://localhost:1234

(lldb)image list -o -f    获得各个库的映射起始地址,如果去掉了ASLR的话,你会发现App映射的起始地址为0x0

(lldb)br s -a 0x3e000   设置断点地址

(lldb)po $r0          在ARM汇编中r0通常存储的是类的地址,使用po命令会显示类的description,实际上应该是调用[$r0 description]。

我们可以用po命令来显示调用类的所有函数,如po [$r0 length],这可以让我们做很多事,世界更简单了。

剩下的就是体力活了。

六,(可选)去掉ASLR

    在使用lldb进行动态调试时,会遇到一个不大不小的问题,就是因为ASLR的存在,每次App可执行文件的起始地址都不一样,所以动态调试的时候各个函数地址和静态分析的地址不一样。当然你可以每次启动的时候手工计算一下,但也可以一劳永逸解决这个问题,就是修改App头文件中的一个比特。

    我们使用change_mach_o_flags.py来去掉这个比特。将App的可执行文件拷贝到Mac上,运行:

$otool -hv xxx   查看头部信息

$python  change_mach_o_flags.py --no-pie xxx

$otool -hv xxx  再查看头部信息,会发现pie已经去掉了。

再将可执行文件拷贝回手机。因为是越狱的手机,代码的完整性检测功能已经名存实亡了。所以修改过的可执行文件可以照常执行。

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

推荐阅读更多精彩内容