iOS逆向环境介绍
*** 越狱环境:iphone5s iOS 8.3***
luz-iphone:~ root# uname -a
Darwin luz-iphone 14.0.0 Darwin Kernel Version 14.0.0: Sun Mar 29 19:47:37 PDT 2015; root:xnu-2784.20.34~2/RELEASE_ARM64_S5L8960X iPhone6,2 arm64 N53AP Darwin
1. Drawin体系
Drawin是一种类似unix的操作系统,他的核心XNU,XNU是一种混合式内核,结合了mach与BSD两种内核
主流的类unix:
- Linux 由Linus Torvalds研发的,代表发行版本CenOS,Redhat,Ubuntu,Debian,openWRT等
- Mac OS X的Intel部分
- freeBSD 由加州大学伯克利分校基于UNIX研发的(UNIX变种,当时如果不是与贝尔实验室打官司,可能就不会有现在的Linux什么事)
- Solaris 由Sun(现为Oracel)开发的UNIX商业版本
BSD 实现在Mach的上层,这一层提供的API 支持了POSIX标准模型。在XNU中主要实现了一些高级的API与模块
UNIX 进程模型
== e.g fork,vfork,wait,waitpid,exec等 ==
POSIX 线程模型即pthread,以及相关的同步功能
== e.g pthread_create,pthread_mutex(线程互斥锁)==
UNIX的用户与组管理
==e.g root用户,mobile用户,chmod等==
网络协议栈(BSD Socket API),符合POSIX 模型
== e.g socket();bind(); listen();accept();connect(); gethostbyname(); gethostbyaddr()等伯克利套接字API==
文件系统/设备系统
== e.g Filesystem Hierarchy Standard(文件系统层次化标准)==
iOS,OSI,ISO的含义
- iOS 苹果公司开发的移动操作系统
- OSI 是Open System Interconnection的缩写,意为开放式系统互联。OSI模型把网络通信的工作分为7层,分别是物理层、数据链路层、网络层、传输层、会话层、表示层和应用层。
- ISO是国际标准化组织。上面的OSI模型由该组织制定。一般类UNIX系统都基本符合POSIX标准和ISO C标准
- POSIX表示可移植操作系统接口(Portable Operating System Interface)
- ISO C标准,C语言标准库接口
为什么越狱
- 突破iOS沙盒机制的限制(sandbox)
== 沙盒是一种安全机制,为运行中的程序提供隔离环境。沙盒在启动的时候可以设置运行的程序是否可以访问网络、文件、目录等==