A-A+

iOS逆向之文件系统结构

博客主机

1.系统文件结构

  • 系统文件

在手机终端执行uname -a 命令,终端可以在cydia中安装MTerminal插件. 执行命令后,可以看到iOS系统基于Darwin Kernel的,而Darwin Kernel是一种UNIX-like操作系统.

  • 文件目录 在越狱设备上,可视化方式查看iOS系统文件
  • 相对于一般的iOS开发者来说,可能对iOS系统结构一无所知.因为权限低,App不能访问自身以外的绝大多数文件.
  • iOS一旦越狱,就可以拥有更高的root权限,从而访问全系统文件.
  • 如何查看文件目录?

1.在MacOS上可以安装itools

2.在MacOS上也可以安装iFunBox

3.在iOS越狱设备Cydia中安装iFile(如果要访问越狱设备的文件系统,需要打开Cydia,安装Apple File Conduit "2")

4.可以通过SSH远程登录iOS来查看,

文章中有介绍,如何通过ssh远程登录,Cydia中使用到了OpenSSH插件.详情请看文章汇编逆向工具集(二)

  • 文件目录结构
    • iOS是OSX演化而来的,而OSX则是基于UNIX操作系统的.
    • Filesystem Hierarchy Standard (文件系统层次化标准简称FHS),FHS为类UNIX操作系统的文件目录结构指定了一套标准,目的是让用户预知文件或目录的存放位置.

UNIX操作系统的常见目录结构如下所示:

上图目录中的内容多用于系统底层.

下面接着介绍iOS的独有目录.

Application 存放所有的系统App和来自于Cydia的APP,不包括APPStore下载的App.
Developer:供开发者使用
Library: 系统资源,用户设置
- Logs是系统日志
- Ringtones是系统自带铃声
- Launch Daemons是启动daemon程序
- MobileSubstrate,里面存放了所有基于Cydia Substrate的插件
System:系统的重要组成部分
- /System/Library/Carrier Bundles里面是运营商的一些配置
- /System/Library/Frameworks;/System/Library/PrivateFrameworks里面
是系统中各种公开与未公开的Framework
- /System/Library/CoreServices里的SpringBoard.app是桌面管理器,是用
户和系统直接交互的中介.
- /System/Library/PerferenceBundles里面存放的系统设置中的一些设置项.
User:用户目录,实际指向/var/mobile
- 这个目录里存放大量用户数据
- /User/Media/里面存放的是相册等
- /User/Library/里面存放的是短信,邮件等
- /var/mobile/Media/DCIM下存放照片
- /var/mobile/Media/Recordings下存放录音文件
- /var/mobile/Library/SMS 下存放短信数据库
- /var/mobile/Library/Mail 下存放邮件数据
- /var/mobile/Containers,存放AppStore下载的app,App的可执行文件在bundle与App中的数据目录被分别存放在
/var/mobile/Containers/Bundle
和/var/mobile/Containers/Data
bin:存放用户级二级制文件
- 比如mv,ls等
dev:设备文件
- 每个设备在/dev目录下都有一个对应的文件
etc:存放系统脚本,hosts配置,SSH配置文件等
sbin:存放系统级二进制文件
比如reboot,mount等
usr:用户工具和程序
- /usr/include存放标准C头文件
- /usr/lib中存放库文件
var:一些经常改动的文件
- 钥匙串keychains,临时文件,从AppStore下载的应用.
  • iOS应用的沙盒目录

1.Application Bundle包含应用可执行文件和资源文件

如果获取应用的Bundle路径,可以通过ps -e | grep appname 查看应用的Bundle路径

2.Applicaiton Data 包含APP运行产生的数据和配置信息

如果获取应用的Data路径,可以通过Cycript工具
cycript  -p 应用名
cy# directory = NSHomeDirectory()
@"/var/mobile/Containers/Data/Application/xx"

3.Data目录结构

1.Document 存放应用运行时生成的并且需要保存的数据。注:iTunes或iCloud同步设备时会备份该目录

2.Library/Caches 存放应用运行时生成的并且需要保存的数据。iTunes或iCloud不同步。

3.Library/Preferences 存放偏好设置。iOS的偏好设置(settings)应用
也会在该目录查找应用的设置信息。NSUserDefaults保存在该目录下。
iTunes或iCloud同步设备时备份该目录。

4.tmp存放应用运行时所需的临时数据。当某个应用没运行时,iOS系统可能会清除该目录下的文件。
但不可依赖这种自动清除机制,应该及时手动清除。
标签:

给我留言

Copyright © ios教程,苹果粉丝,苹果资讯,ios入门教程,ios学习,ios程序员,ios视频教程,ios粉丝网 保留所有权利.   Theme  Ality

用户登录