iOS APP 簽名原理

流程

iOS App簽名

1.在你的 Mac 開(kāi)發(fā)機(jī)器生成一對(duì)公私鑰较木,這里稱為公鑰L,私鑰L表蝙。L:Local

2.蘋果自己有固定的一對(duì)公私鑰拴测,跟上面 AppStore 例子一樣,私鑰在蘋果后臺(tái)府蛇,公鑰在每個(gè) iOS 設(shè)備上。這里稱為公鑰A屿愚,私鑰A汇跨。A:Apple

3.把公鑰 L 傳到蘋果后臺(tái),用蘋果后臺(tái)里的私鑰 A 去簽名公鑰 L妆距。得到一份數(shù)據(jù)包含了公鑰 L 以及其簽名穷遂,把這份數(shù)據(jù)稱為證書。

4.在蘋果后臺(tái)申請(qǐng) AppID娱据,配置好設(shè)備 ID 列表和 APP 可使用的權(quán)限蚪黑,再加上第③步的證書,組成的數(shù)據(jù)用私鑰 A 簽名,把數(shù)據(jù)和簽名一起組成一個(gè) Provisioning Profile 文件忌穿,下載到本地 Mac 開(kāi)發(fā)機(jī)抒寂。

5.在開(kāi)發(fā)時(shí),編譯完一個(gè) APP 后掠剑,用本地的私鑰 L 對(duì)這個(gè) APP 進(jìn)行簽名屈芜,同時(shí)把第④步得到的 Provisioning Profile 文件打包進(jìn) APP 里,文件名為embedded.mobileprovision朴译,把 APP 安裝到手機(jī)上井佑。

6.在安裝時(shí),iOS 系統(tǒng)取得證書眠寿,通過(guò)系統(tǒng)內(nèi)置的公鑰 A躬翁,去驗(yàn)證embedded.mobileprovision的數(shù)字簽名是否正確,里面的證書簽名也會(huì)再驗(yàn)一遍盯拱。

7.確保了embedded.mobileprovision里的數(shù)據(jù)都是蘋果授權(quán)以后盒发,就可以取出里面的數(shù)據(jù),做各種驗(yàn)證坟乾,包括用公鑰 L 驗(yàn)證APP簽名迹辐,驗(yàn)證設(shè)備 ID 是否在 ID 列表上,AppID 是否對(duì)應(yīng)得上甚侣,權(quán)限開(kāi)關(guān)是否跟 APP 里的 Entitlements 對(duì)應(yīng)等明吩。

開(kāi)發(fā)者證書從簽名到認(rèn)證最終蘋果采用的流程大致是這樣,還有一些細(xì)節(jié)像證書有效期/證書類型等就不細(xì)說(shuō)了殷费。

解釋

上面的步驟對(duì)應(yīng)到我們平常具體的操作和概念是這樣的:

1.第 1 步對(duì)應(yīng)的是 keychain 里的 “從證書頒發(fā)機(jī)構(gòu)請(qǐng)求證書”印荔,這里就本地生成了一堆公私鑰,保存的CertificateSigningRequest就是公鑰详羡,私鑰保存在本地電腦里仍律。

2.第 2 步蘋果處理,不用管实柠。

3.第 3 步對(duì)應(yīng)把CertificateSigningRequest傳到蘋果后臺(tái)生成證書水泉,并下載到本地。這時(shí)本地有兩個(gè)證書窒盐,一個(gè)是第 1 步生成的草则,一個(gè)是這里下載回來(lái)的,keychain 會(huì)把這兩個(gè)證書關(guān)聯(lián)起來(lái)蟹漓,因?yàn)樗麄児借€是對(duì)應(yīng)的炕横,在XCode選擇下載回來(lái)的證書時(shí),實(shí)際上會(huì)找到 keychain 里對(duì)應(yīng)的私鑰去簽名葡粒。這里私鑰只有生成它的這臺(tái) Mac 有份殿,如果別的 Mac 也要編譯簽名這個(gè) App 怎么辦膜钓?答案是把私鑰導(dǎo)出給其他 Mac 用,在 keychain 里導(dǎo)出私鑰卿嘲,就會(huì)存成.p12文件颂斜,其他 Mac 打開(kāi)后就導(dǎo)入了這個(gè)私鑰。

4.第 4 步都是在蘋果網(wǎng)站上操作腔寡,配置 AppID / 權(quán)限 / 設(shè)備等焚鲜,最后下載 Provisioning Profile 文件。

5.第 5 步 XCode 會(huì)通過(guò)第 3 步下載回來(lái)的證書(存著公鑰)放前,在本地找到對(duì)應(yīng)的私鑰(第一步生成的)忿磅,用本地私鑰去簽名 App,并把 Provisioning Profile 文件命名為embedded.mobileprovision一起打包進(jìn)去凭语。這里對(duì) App 的簽名數(shù)據(jù)保存分兩部分葱她,Mach-O 可執(zhí)行文件會(huì)把簽名直接寫入這個(gè)文件里,其他資源文件則會(huì)保存在_CodeSignature目錄下似扔。

第 6 - 7 步的打包和驗(yàn)證都是 Xcode 和 iOS 系統(tǒng)自動(dòng)做的事吨些。

其他

1.證書:內(nèi)容是公鑰或私鑰,由其他機(jī)構(gòu)對(duì)其簽名組成的數(shù)據(jù)包炒辉。

2.Entitlements:包含了 App 權(quán)限開(kāi)關(guān)列表豪墅。

3.CertificateSigningRequest:本地公鑰。

4 p12:本地私鑰黔寇,可以導(dǎo)入到其他電腦偶器。

5.Provisioning Profile:包含了 證書 / Entitlements 等數(shù)據(jù),并由蘋果后臺(tái)私鑰簽名的數(shù)據(jù)包缝裤。

參考

iOS APP 簽名原理

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末屏轰,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子憋飞,更是在濱河造成了極大的恐慌霎苗,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件榛做,死亡現(xiàn)場(chǎng)離奇詭異唁盏,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)检眯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門升敲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人轰传,你說(shuō)我怎么就攤上這事”衿玻” “怎么了获茬?”我有些...
    開(kāi)封第一講書人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵港庄,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我恕曲,道長(zhǎng)鹏氧,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任佩谣,我火速辦了婚禮把还,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘茸俭。我一直安慰自己吊履,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布调鬓。 她就那樣靜靜地躺著艇炎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪腾窝。 梳的紋絲不亂的頭發(fā)上缀踪,一...
    開(kāi)封第一講書人閱讀 51,292評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音虹脯,去河邊找鬼驴娃。 笑死,一個(gè)胖子當(dāng)著我的面吹牛循集,可吹牛的內(nèi)容都是我干的唇敞。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼暇榴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼厚棵!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起蔼紧,我...
    開(kāi)封第一講書人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤婆硬,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后奸例,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體彬犯,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年查吊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了谐区。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡逻卖,死狀恐怖宋列,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情评也,我是刑警寧澤炼杖,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布灭返,位于F島的核電站,受9級(jí)特大地震影響坤邪,放射性物質(zhì)發(fā)生泄漏熙含。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一艇纺、第九天 我趴在偏房一處隱蔽的房頂上張望怎静。 院中可真熱鬧,春花似錦黔衡、人聲如沸蚓聘。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)或粮。三九已至,卻和暖如春捞高,著一層夾襖步出監(jiān)牢的瞬間氯材,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工硝岗, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留氢哮,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓型檀,卻偏偏與公主長(zhǎng)得像冗尤,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子胀溺,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容