来源:http://disp.cc/b/522-4v3W

最近有一場Jailbreak的conference,叫做WWJC

裡面請到很多駭客來講解越獄相關知識

包括p0sixninja, iH8sn0w, pod2g等等

其中iH8sn0w的演講主要在講SHSH以及iOS降級

影片在http://www.youtube.com/watch?feature=player_embedded&v=ltBwbSc_j28

iH8Sn0w Keynote - JailbreakCon 2012 (WWJC) - YouTube

Tweet This Video:  Follow: @JailbreakCon Social Network: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  Facebook:...

投影片在http://tinyurl.com/8wmej24

內容大致整理如下,我自己加上了一點背景知識讓文章比較好讀:

1. 什麼是SHSH?

   簡單的說從iPhone 3GS以來任何iDevice要安裝iOS都需要經過Apple的認可,而Apple

   一般來說只會認可最新版的iOS。SHSH可以看做是Apple的簽名,iTunes必須要收到

   Apple發的合格SHSH才會進行韌體回復。

   SHSH只跟兩樣東西有關,一個是iOS版本,一個是iDevice的獨一無二晶片碼ECID,

   所以你的iDevice要安裝某個版本的iOS,你需要有Apple發給你的機器專屬的該iOS

   版本SHSH,不能用別人的,也不能用其他iOS版本的,跟你機器裡裝啥無關。

 

2. SHSH哪裡來?怎麼用來降級?

   SHSH理論上是從Apple發的,Apple只會發最新版本的iOS的SHSH,但是因為SHSH只跟

   iOS版本以及機器ECID有關,所以舉例來說,可以在5.0為最新時跟Apple要5.0 SHSH

   等到5.1出了以後,你把之前存好的5.0 SHSH餵給iTunes,iTunes以為是Apple簽的,

   於是就開始刷5.0,也就是所謂的降級/平刷/非升級到最新版。

   沒有備份SHSH的狀況下,你只能從Apple去取得SHSH,當然只有最新版iOS的,也就是

   iTunes只能幫你安裝最新版的iOS,謂之強迫升級。

 

3. SHSH為什麼失效了?

   在iOS 5.0開始,Apple Server除了發SHSH還多發了一個叫APTicket的東西。

   這是什麼東西呢?SHSH是把ECID跟iOS版本送去給Apple簽名得到的產物,ApTicket

   也是請Apple簽名...但是簽的是一個Nonce,它是一個隨機產生的72-Byte 16進位碼

   就是一個隨機的東西啦!

   看出問題了嗎?因為SHSH只跟ECID以及iOS版本有關,只要你的ECID跟iOS版本不變,

   iTunes根本分不出來你是備份好的還是Apple新發的

   可是APTicket就不一樣了,每次都是隨機產生的,所以你拿之前舊的餵給iTunes

   馬上就會被抓到,也就是單純靠SHSH來降級已經做不到了。

   所以嚴格來說,不是SHSH不見了或者沒用了,它還是要用來簽一部分的韌體

   (LLB跟iBoot),只是光靠SHSH完成不了重刷,還需要APTicket。

 

4. 那為什麼好像iOS5在有些條件下還是可以降級?

   問的好,希望答案不會讓你睡著XD

   A4 Device(iPad1, iPhone4)以及iPhone3GS都可以直接使用SHSH降級,因為有個硬體

   上的漏洞存在,所以很容易(?)可以繞過APTicket的檢查(當然還是要有SHSH)

   A5開始就比較麻煩了,因為沒有硬體上的漏洞,所以需要一些新的手法。

   首先要知道iPhone的韌體ipsw在安裝時,如果已經有合法的SHSH等等,都會被iTunes

   一起包進ipsw然後一起刷進手機。所以APTicket也不例外。在安裝時機器裡已經有

   一個APTicket,記錄一個iOS版本和對應的隨機碼Nonce,在刷韌體的過程第一個

   程序是iBEC,他也有記錄一個iOS版本,只要可以把iOS5.x的iBEC刷進去執行,

   接下來就可以刷該版本的iOS。那Apple是怎麼決定要不要讓你刷某版本的iBEC呢?

   理論上要用APTicket來驗證,可是在某一個狀況不能這樣做。

   猜到了嗎?就是OTAUpdate。因為在OTAUpdate開始後,你是不可能上網的(哪有手機

   一邊升級自己一邊上網的...),所以Apple的檢查很簡單,就看機器裡面的APTicket

   版本,然後接受你刷同版本或更高級的iBEC。在正常的OTAUpdate下,這個APTicket

   是Apple在update開始前送進手機的。

   好了,那要降級的話,概念就很簡單,我要想辦法刷進一個比較低版本的APTicket。

   取得這個不是很難,因為從iOS5開始小雨傘在幫你存SHSH時也順手幫你存了一個該版本

   的APTicket,當然因為Nonce的關係他沒辦法直接像SHSH一樣使用,但是它是有用的!

   現在問題是要怎麼把它刷進去。

   假設要從5.1.1降級到5.0.1,步驟大致上是這樣:

   你的機器安裝了5.1.1,裡面的APTicket也是5.1.1,根據前面的規則,可以安裝並

   執行>=5.1.1的iBEC,所以我們開始執行了5.1.1的iBEC。

   接下來iTunes會開始安裝5.1.1,但是我們把韌體一部分改掉了,把5.0.1的APTicket

   偷偷塞進去,然後接下來的LLB跟iBoot兩個程序只需要用SHSH簽,所以也可以用備份

   SHSH簽好一起混進去。所以就是整個韌體檔多了5.0.1的APTicket,被換掉了LLB跟

   iBoot,其他不變。刷機的過程來到5.0.1的iBoot,此時就會達到可以安裝5.0.1 iBEC

   的狀態,把這個5.0.1的iBEC裝進去後,又根據前面的一個規則,只要開始跑5.0.1的

   iBEC你就可以刷整個5.0.1,降級完成!

 

5. 那iOS6惹出了什麼麻煩?

   現在只要APTicket不合格整個重刷的過程就會直接error跳出,加上Apple開始檢查

   你在韌體裡動什麼手腳。以前可以把APTicket混進去刷但是現在就會被抓到了...

 

6. 那現在狀況是?

   A4系列以及3GS已經講過,因為bootrom洞很大所以有SHSH就夠了

   iPad 2有4.3 SHSH一樣可以降級到任何有SHSH+APTicket的版本,因為4.3根本沒有

   APTicket,故可以用之前iBEC >= APTicket那招來裝舊版iBEC=>舊版iOS

   iPad3跟iPhone4S目前可以平刷iOS 5.x,理由就是之前的iBEC版本需>=機器裡的

   APTicket版本+只要iBEC開始跑就可以刷跟iBEC同版本的iOS,只是現在因為沒辦法

   再把舊版APTicket偷渡進去,故現在只有平刷的選擇。

 

7. 那iPhone 5?

   iPhone5在硬體裡面就會檢查簽名,可是完全不檢查SHSH只檢查APTicket。

   (其他機器現在是SHSH和APTicket並行)

   不過反正iPhone5也沒有什麼可以降級的啊XD

 

BTW,iH8sn0w今年才17歲,雖然沒有geohot or comex猛,但是在大部分是大叔的駭客圈

也已經相當不簡單了...

[转]SHSH, APTicket以及iOS降級的更多相关文章

  1. iPhone 3gs 5.0.1降級到4.3.3 昨晚搞定(有shsh備份)

    經過昨天白天一天的學習和準備,終於一次降級成功. 手機未降級時狀態: 無鎖港版   3GS 16G  固件:5.0.1  基帶:05.16.05 記錄且分享降級完整步驟: 準備以下軟件.工具 官網固件 ...

  2. 使用 NuGet 更新套件時將 jQuery 升級到 2.0.2 應該如何降級

    我們在 Visual Studio 2012 裡面會使用 NuGet 管理員管理那些常用的開發函式庫,例如jQuery.Json.NET. EntityFramework.ELMAH.… 等等.各位可 ...

  3. 偏执的iOS逆向研究员:收集全版本的macOS iOS+越狱+内核调试

    Intro 虽然“只有偏执狂才能够生存”这句话已经被假药停给毁了,但是作为一只有逼格的高大上的iOS逆向分析研究员,难道如果有现成的macOS/iOS全版本镜像可以下载并且无限“漫游”,难道你就不想来 ...

  4. Unity3D教程:茄子童萌會

    http://s.epb.idv.tw/han-shi-ku/unity Unity 0000 Unity3D學習之路 - C#學習筆記(一) 0001 Unity3D學習之路 - C#學習筆記(二) ...

  5. 比較Backbone.js, Angular.js, Ember.js, Knockout.js 心得

    還記得第一次寫網站的時候,我無意間寫成了 SPA(single page application),當時還沒有SPA這個詞,後來因為廣告主需要不同 url location 頁面的廣告展示,只好把部分 ...

  6. VMware虛擬化技術實作問答

    http://www.netadmin.com.tw/article_content.aspx?sn=1202130002&ns=1203280001&jump=3 Q4:啟用VMwa ...

  7. Exchange Version and UpdateRollups

    Exchange Server 2010 Product name Build number Date KB Microsoft Exchange Server 2010 RTM 14.0.639.2 ...

  8. IE Error: '__doPostBack' is undefined 问题解决

    突然遇到个很奇怪的BUG,翻页控件,其他浏览器一切正常,IE无法翻页,会提示 '__doPostBack' is undefined 后来搜索发现: [原文發表地址] Bug and Fix: ASP ...

  9. H5 App如此强悍,要降薪的恐怕已不只是iOS程序员

    2015年的最后几天,移动开发圈里最为火爆的话题之一无疑是“iOS程序员月薪降至12K”这则报道. 有人认为这是O2O创业遇冷所致,也有人认为这是iOS生态过于封闭致使智能硬件等新领域对iOS开发者的 ...

随机推荐

  1. 谈论Hibernate级联删除——JPA根据Hibernate实现许多级联删除CascadeType.DELETE_ORPHAN

    声明: 1.这篇文章是原创.非复制或转载过来. 2.在本文中,参数都亲自做过实验证明. 3.这篇文章谈到了Hibernate配置基于注释的方法.hbm语法不可用. 不清JPA.Hibernate.EJ ...

  2. 《STL源代码分析》---stl_list.h读书笔记

    STL在列表list它是一种经常使用的容器.list不连续双向链表在内存,而且是环形. 理解列表如何操作的详细信息,然后.阅读STL名单上的代码是最好的方法. G++ 2.91.57.cygnus\c ...

  3. SQL字符串转换为数组

    /*一.按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果. -----rtrim(@str)去掉 @str右边的字符 ltrim(@ ...

  4. iOS使用UIScrollView实现左右滑动UITableView和UICollectionView

    在UIScrollView嵌套UITableView这篇文章是非常,但该项目的需求,需要嵌套UICollectionView,和UICollectionView和UITableView有非常多的不同, ...

  5. wcf系列5天速成——第一天 binding的使用(1)

    原文:wcf系列5天速成--第一天 binding的使用(1) 作为WCF速成系列,只介绍些项目开发中常用到的实战知识. 学习wcf,还是对其中的几个术语要了解一下.wcf中有一个ABC的概念,就是 ...

  6. CSharp设计模式读书笔记(17):迭代器模式(学习难度:★★★☆☆,使用频率:★★★★★)

    迭代器模式(Iterator Pattern):提供一种方法来访问聚合对象,而不用暴露这个对象的内部表示,其别名为游标(Cursor). 模式角色与结构: 实现代码: using System; us ...

  7. HDU多赛学校9 HDU4969 Just a Joke 【数学积分】

    数学题目 意甲冠军:的男孩向圆上的女孩跑去,保持男孩女孩圆心在同一条直线上.这过程中,男孩女孩均匀速 给出男孩女孩速度,圆的半径,男孩最长能跑的距离 问男孩是否能跑到女孩那里 能够用积分来解这道题,我 ...

  8. MVC Bootstrap Helpers

    ASP.NET MVC Bootstrap Helpers   阅读目录 序言 内置的HTML Helpers 创建自定义的Helpers 使用静态方法创建Helpers 使用扩展方法创建Helper ...

  9. java界面编程(8) ------ 组合框(下拉列表)

    本文是自己学习所做笔记,欢迎转载,但请注明出处:http://blog.csdn.net/jesson20121020 与一组单选button的功能类似,组合框(下拉列表)也是强制用户从一组可能的元素 ...

  10. Java-继承特性

    继承的特点: 1.提高了代码的复用性. 2.让类与类之间发生了关系,有了这个关系,才有了多态的特性. (注意:千万不要为了获取其他类的功能,简化代码而继承:必须是类与类之间有所属关系才可以继承,所属关 ...