iOS 越狱环境搭建

学前须知

一定的基础知识

如果想研究逆向其实是需要一定的iOS开发功底和经验的,怎么也得做过一两年,完成过几个项目,对UI、多线程网络、数据存储都要有一定的知识储备。

设备要求

iPhone 6/6s即可,建议至少iPhone 5S(因为从5S开始支持arm64架构)或者至少是iPad Air、iPad mini2等支持arm64架构的设备
至于iOS系统,我使用的是iOS 9.1完美越狱,建议至少iOS 8完美越狱,注意要保证能够完美越狱
检查手机是否可以越狱

iOS Jailbreak

利用iOS系统的漏洞,获取iOS系统的最高权限(Root),解开之前的各种限制,这是一个合法行为)

越狱的优点

  • 利用iOS越狱我们可以打造个性化、与众不同的iPhone
  • 可以自由安装各种实用的插件、主题、APP
  • 修改系统APP的一些默认行为,自由安装非AppSore来源的APP
  • “付费APP”秒变“免费APP”
  • 灵活管理文件系统,让iPhone可以像U盘一样使用
  • 最有用的就是给开发者提供了逆向工程的环境

越狱的缺点

  • 不予保修
  • 费电,越狱后的iOS系统会常驻一些进程,耗电速度约提升10%~20%
  • 在新的iOS固件版本出来的时候,不能及时地进行更新,每个新版本的固件,都会修复上一个版本的越狱漏洞,使越狱失效,如果需要保持越狱状态,要等待新的越狱程序发布时,才能升级相应的固件版本
  • 不再受iOS系统默认的安全保护,容易被恶意软件攻击,个人隐私有被窃取的风险
  • 如果安装了不稳定的插件,容易让系统变得不稳定、变慢,甚至出现“白苹果”等问题

越狱分类

  1. 完美越狱
    越狱后的iPhone可以正常关机和重启

  2. 不完美越狱
    iPhone一旦关机后再开机时,屏幕就会一直停留在启动画面,也就是“白苹果”状态
    或者能正常开机,但已经安装的破解软件都无法正常使用,需要将设备与PC连接后,使用软件进行引导才能使用

    一般说来,在苹果发布新的iOS固件后,针对该固件的不完美越狱会先发布,随后完美越狱才可能发布,一般较新的系统版本,均为不完美越狱

越狱方法推荐 PP助手

通过判断手机是否越狱

方案一:桌面是否有Cydia或者工具判断PP助手

方案二:代码判断是否安装Cydia

@interface UIDevice (Helper)  
- (BOOL)isJailbroken;  
@end

@implementation UIDevice (Helper)  
- (BOOL)isJailbroken {  
  BOOL jailbroken = NO;  
  NSString *cydiaPath = @"/Applications/Cydia.app";  
  NSString *aptPath = @"/private/var/lib/apt/";  
  if ([[NSFileManager defaultManager] fileExistsAtPath:cydiaPath]) {  
    jailbroken = YES;  
  }  
  if ([[NSFileManager defaultManager] fileExistsAtPath:aptPath]) {  
    jailbroken = YES;  
  }  
  return jailbroken;  
}  
@end
+ (BOOL)isJailbroken; //类方法,判断你的App是否被破解
+ (BOOL)isPirated;

然后再介绍两种方法来查看是否已经越狱,知其然知其所以然、、、

//1. apt
- (BOOL) hasAPT
{
  return [[NSFileManager defaultManager] fileExistsAtPath:@"/private/var/lib/apt/"];
}
//2. system
- (BOOL) successCallSystem
{
  return (system("ls") == 0) ? YES : NO;
}
//3.
  staticconstchar* jailbreak_apps[] =
    {
        "/Applications/Cydia.app", 
        "/Applications/limera1n.app", 
        "/Applications/greenpois0n.app", 
        "/Applications/blackra1n.app",
        "/Applications/blacksn0w.app",
        "/Applications/redsn0w.app",
        "/Applications/Absinthe.app",
        NULL,
    };
- (BOOL) isJailBroken
   {
        // Now check for known jailbreak apps. If we encounter one, the device is jailbroken.
        for(inti = 0; jailbreak_apps[i] != NULL; ++i)
        {
            if([[NSFileManagerdefaultManager] fileExistsAtPath:[NSStringstringWithUTF8String:jailbreak_apps[i]]])
            {
                //NSLog(@"isjailbroken: %s", jailbreak_apps[i]);
                returnYES;
            }
        }
        // TODO: Add more checks? This is an arms-race we're bound to lose.
        returnNO;
 }

但是可能不在这个位置,所以不准确

Cydia

它相当于越狱后的“App Store”,我们可以在Cydia中安装各种第三方的软件(插件、补丁、APP)作者:Jay Freeman (saurik)

使用Cydia安装软件

  1. 添加软件源(不同软件的软件源可能不同)

  2. 进入软件源找到对应的软件,开始安装
    如果软件源中的软件太多,可以搜索查找

有时候通过Cydia安装完插件后,可能会出现重启SpringBoard,SpringBoard其实就是iOS的桌面

必要的软件和插件

  1. Apple File Conduit "2"
    Apple File Conduit "2"补丁的作用
    可以访问整个iOS设备的文件系统
    类似的补丁还有:afc2、afc2add
    软件源 :http://apt.saurik.comhttp://apt.25pp.com

  2. AppSync Unified
    AppSync Unified补丁的作用
    可以绕过系统验证,随意安装、运行破解的ipa安装包
    软件源:http://apt.25pp.com

  3. iFile
    iFile的作用
    可以在iPhone上自由访问iOS文件系统
    类似的还有Filza File Manager、File Browser
    软件源:http://apt.thebigboss.org/repofiles/cydia

  4. PP助手
    可以利用PP助手自由安装海量APP
    软件源:http://apt.25pp.com/

安装建议顺序:


image.png

通常情况下

  • 通过Cydia安装的安装包是deb格式的(结合软件包管理工具apt)
  • 通过PP助手安装的安装包是ipa格式的

如果通过Cydia源安装deb失败
可以先从网上下载deb格式的安装包
然后将deb安装包放到/var/root/Media/Cydia/AutoInstall
重启手机,Cydia就会自动安装deb

比如,下图是iFile 2.2.0-1所需的deb安装包


image.png

Mac必备

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

推荐阅读更多精彩内容