iOS 逆向工程看书笔记day01

第一部分 概念篇

第1章 iOS逆向工程简介

软件逆向工程,指的是通过分析一个程序或系统的功能、结构或行为,将它的技术实现或细节推导出来的过程。

1.1 iOS逆向工程的要求
最好能非常熟悉iOS的硬件构成、iOS系统的运行原理,还要具备丰富的iOS开发经验。(充分非必要条件)但有两个必要条件强烈的好奇心和锲而不舍的精神。

1.2 iOS应用逆向工程的作用
基于iOS逆向工程技术,可以在不破坏城墙的前提下,选择任意高纬度地点进入低纬度城堡,巧取而不强夺,通过监视甚至改变App的运行逻辑,从而达到获取核心信息,了解软件原理等战术目的。

1.2.1 安全相关的iOS逆向工程
1.评定安全等级
2.逆向恶意软件
3.检查软件后门
4.取出软件使用限制

1.2.2开发相关的iOS逆向工程
1.逆向系统API
2.借鉴别的软件

1.3 iOS应用逆向工程的过程
一般来说,软件逆向工程可以看做 系统分析 和 代码分析 两个阶段的有机结合。

在系统分析阶段,应在不同的条件下运行目标程序,在程序中改进型各种各样的操作,观察程序的行为特征,同时寻找我们感兴趣的功能点。还可以浏览文件系统,观察程序显示的图片、程序的配置文件存放的位置,数据库文件中存放了哪些信息,有没有加密等特征。

完成了系统分析之后,就该对App的二进制文件进行代码分析了。通过逆向工程可以推倒出这个App的设计思路、内部算法和实现细节,但这是一个非常复杂的过程。(难点)

1.4 iOS 应用逆向工程的工具
四大类:监测工具、反汇编工具(disassembler)、调试工具(debugger),以及开发工具

1.4.1 监测工具
起到嗅探、监测、记录目标程序行为的工具统称为监测工具,这些工具通常可以记录并显示目标程序的某些操作,如UI变化、网络活动、文件访问等。常用工具有Reveal、snoop-it、introspy

1.4.2 反汇编工具
IDA 逆向工程中最常用的利器之一
Hopper
把二进制文件反汇编之后,就要阅读成成的汇编代码了,这是iOS逆向工程中最具挑战,也是最有意思的部分。

1.4.3 调试工具 Xcode LLDB

1.4.4 开发工具
越狱iOS 基于Xcode iOSOpenDev
偏命令行的 Theos

2.1 iOS 系统结构
Cydia 的 iFile 可以获取到文件管理

53755EF9-AB52-4CFD-9B09-1840B731475F.png

还可以在AFC2服务的帮助下,通过iFunBox 等PC端软件访问iOS权系统文件
因为要你行的对象来自于iOS,所有能够访问iOS全系统文件是开展iOS逆向工程的首要前提。

2.1.1 iOS 目录结构简介
Filesystem Hierarchy Standard (FHS) 和 hier(7)为iOS目录结构的设计标准

./: 根目录

./bin: binary 的简写,存放提供用户级基础功能的二进制文件,如ls、ps等

./boot: 存放能使系统成功启动的所有文件。iOS中此目录为空。

./dev device 的简写,存放BSD设备文件。每个文件代表系统的一个块设备或字
符设备,一般来说,块设备 以块为单位传输数据,如硬盘;而字符设备 以字符为单位传输数据,如调制解调器。

./sbin: system binaries 的简写,存放提供系统级基础功能的二进制文件,如netstat、reboot等

./etc: Et Cetera 的简写,存放系统脚本及配置文件,如passwd、hosts等。在iOS中,/etc是一个符号链接,实际指向/private/etc.

./lib: 存放系统库文件、内核模块及设备驱动等。iOS此陌路为空。

./mnt: mount 的简写,存放临时的文件系统挂载点。iOS中此目录为空。

./private: 存放两个目录,分别是/private/etc 和 /private/var。

./tmp: 临时目录。在iOS中, /tmp是一个符号链接,实际指向/private/var/tmp

./usr: 包含了大多数用户工具和程序。/usr/bin 包含那些/bin 和 /sbin 中未出现的基础功能,如nm、killall等; /usr/include 包含所有的标准C头文件;/usr/lib存放库文件
./var: variable 的简写,存放一些经常更改的文件,比如日志、用户数据、临时文件等。其中/var/mobile 和 /var/root 分别存放了 moblie 用户和 root 用户的文件,是重点关注的目录。

作为iOS开发者 不必太过于关注系统底层,多关注些iOS独有目录。

B0D88A3E-4BF0-4389-AD19-CBEB802F4439.png

./ Application: 存放所有的系统App和来自于Cydia的App,不包括StoreApp

./Developer: 如果一台设备来接Xcode后被制定为吊事用机,Xcode就会在ios中生成这个目录,其中包含有一些吊事需要的工具和数据

A9140E93-A270-43C9-8525-9CAF9B8041E8.png

./Library: 存放一些提供系统支持的数据,其中./Library/MobileSubstrate下存放了所欲基于CydiaSubstrate 的插件

7CC1EA48-A305-46F6-9307-DE30B682E660.png

./System/Library: iOS文件系统中最重要的目录之一,存放大量系统组件,其目录结果

对于该目录,在逆向工程的初学阶段,需要重点关注的有:
./System/Library/Fremeworks 和 System/Librery/PrivateFrameworks:存放iOS中的各种framework,其中出现在SDK文档里的只是冰山一角,还有数不清的未公开功能等待我们去挖掘。

./System/Library/CoreServices里的SpringBoard.app: iOS桌面管理器(类似于Windows的explorer),是用户与系统交流的最重要中介

./User:用户目录,实际指向/var/mobile

5752430A-DF64-4340-B95B-4EDEEA0F1A43.png

这个目录里存放大量用户数据
./var/mobile/Media/DCIM 下存放照片
./var/mobile/Media/Recordings下存放录音文件
./var/mobile/Library/SMS下存放短信数据库
./var/mobile/Library/Mail/下存放邮件数据
另外一个非常重要的子目录是/var/mobile/Conteiners,存放StoreApp。值得注意的是,App的可执行文件在bundle与App中的数据目录被分别存放

4B9559E1-03AB-432C-8440-01F268A5E9FD.png

在/var/mobile/Conteiners/Bundle和/var/mobile/Containers/Bundle 和 /var/mobile/Containers/Data这两个不同目录下

2.1.2 iOS文件权限简介

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

推荐阅读更多精彩内容