iOS中的動(dòng)態(tài)庫(kù)

動(dòng)態(tài)庫(kù)是開(kāi)發(fā)中必然會(huì)用的场钉,在Xcode中我們會(huì)碰到各種格式的“庫(kù)”懈涛,framework、dylib宇植、tbd埋心,其實(shí)系統(tǒng)提供的庫(kù)都是dylib動(dòng)態(tài)庫(kù)。在了解動(dòng)態(tài)庫(kù)之前闲坎,先來(lái)看看tbd是什么東西茬斧,tbd是text-based stub libraries的意思,它是蘋(píng)果從XCode7開(kāi)始使用的一個(gè)技術(shù)绣溜,便于減少XCode中相應(yīng)的SDK的體積娄蔼,說(shuō)白了它就是一個(gè)文本:

CoreTelephony.tbd

tbd文件中有支持的架構(gòu)贷屎、二進(jìn)制文件的位置以及庫(kù)中所有symbols的聲明,它只是動(dòng)態(tài)庫(kù)的一個(gè)描述咒吐。那么framework又是什么樣的呢属划?

Foundation.framework

Foundation.framework也是一個(gè)dylib動(dòng)態(tài)庫(kù)同眯,我們可以看到它目錄下有Headers(public API的頭文件)和同名的tbd。

我們知道動(dòng)態(tài)庫(kù)是在程序運(yùn)行的時(shí)候才加載的硅确,平時(shí)在Xcode中導(dǎo)入的這些framework和tbd只是對(duì)動(dòng)態(tài)庫(kù)的一個(gè)描述,目的是為了告訴編譯器動(dòng)態(tài)庫(kù)中有這么些API缭付,從而成功編譯循未,否則的話(huà)就會(huì)buid failed,原因是Symbol not found绣檬。

那么既然這樣嫂粟,這些動(dòng)態(tài)庫(kù)的二進(jìn)制文件在哪呢?在tbd文件的第四行忘蟹,我們可以看到CoreTelephony動(dòng)態(tài)庫(kù)的二進(jìn)制文件的路徑是/System/Library/Frameworks/CoreTelephony.framework/CoreTelephony搁凸,但是通過(guò)iFile到越獄設(shè)備對(duì)應(yīng)的位置看一下护糖,卻并沒(méi)有對(duì)應(yīng)的文件嚼松,其他的framework也都如此。

真正的動(dòng)態(tài)庫(kù)哪去了寝受?罕偎??

在iOS系統(tǒng)中,系統(tǒng)庫(kù)文件都被打包到一個(gè)緩存的文件當(dāng)中即dyld緩存, dyld緩存位于/System/Library/Caches/com.apple.dyld/目錄下甩苛,文件名是以“dyld_shared_cache_”開(kāi)頭俏站,再加上這個(gè)dyld緩存文件所支持的指令集肄扎。在這個(gè)目錄下赁酝,有可能有多個(gè)dyld緩存文件旭等,對(duì)應(yīng)所支持的不同指令集。目前為止肪笋,所有iOS支持的指令集有四種:(1) armv6 ?(2) armv7 ?(3) armv7s ?(4) armv64度迂。所有指令集是向下兼容的惭墓, 只不過(guò)使用低版本的arm指令集不能充分發(fā)揮硬件性能,iPhone5s開(kāi)始標(biāo)配arm64指令集划咐。(Xcode中的模擬器是x86架構(gòu)钧萍,動(dòng)態(tài)庫(kù)的二進(jìn)制文件可以在Xcode中找到)。

dyld緩存

608.1MB的文件中队魏,包含1014個(gè)動(dòng)態(tài)庫(kù)胡桨,問(wèn)題來(lái)了瞬雹,怎樣提取出這些動(dòng)態(tài)庫(kù)?以前的版本中可以使用jtool或者dyld_decache呢诬,現(xiàn)在只能dsc_extractor了意敛。至于具體的安裝使用過(guò)程,時(shí)間太晚就不寫(xiě)了钓猬,可以自行搜索撩独。或者可以直接下載我提取出來(lái)的文件澳迫,360云盤(pán)分享鏈接:https://yunpan.cn/OckE3mzihiTyip (提取碼:c611)

拿到所有的動(dòng)態(tài)庫(kù)橄登,就可以對(duì)感興趣的進(jìn)行分析了,推薦兩個(gè)反編譯工具:IDA(強(qiáng)烈推薦Rテ蕖W湮取L0搿),可以在windows上跑個(gè)和諧版充坑,或者用mac下的Hopper减江。分析動(dòng)態(tài)庫(kù)的最終目的是使用它,對(duì)于public API捻爷,也不用分析辈灼,直接用就好了;對(duì)于private API也榄,大概分三種茵休,OC、C手蝎、C++,OC的私有API使用方法有很多俐芯,可以用runtime、KVC或者performSelector等等吧史,對(duì)于C和C++的私有API邮辽,可以使用dlopen函數(shù)手動(dòng)打開(kāi)動(dòng)態(tài)庫(kù),dlsym獲取函數(shù)地址贸营,當(dāng)然吨述,要想成功調(diào)用,還需要知道私有的返回值和參數(shù)钞脂,不過(guò)有一些函數(shù)是不需要參數(shù)的(可以試試CoreTelephony中的CTSettingCopyMyPhoneNumber)揣云,而且也有很多函數(shù)是已經(jīng)被開(kāi)發(fā)者破解了的。

如想了解更多冰啃,可以 import <mach-o/dyld.h>瞅瞅邓夕。

大概提一下刘莹,不是很詳細(xì),隨便看看就好

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末焚刚,一起剝皮案震驚了整個(gè)濱河市点弯,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌矿咕,老刑警劉巖抢肛,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異碳柱,居然都是意外死亡捡絮,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén)士聪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)锦援,“玉大人,你說(shuō)我怎么就攤上這事剥悟×樗拢” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵区岗,是天一觀(guān)的道長(zhǎng)略板。 經(jīng)常有香客問(wèn)我,道長(zhǎng)慈缔,這世上最難降的妖魔是什么叮称? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮藐鹤,結(jié)果婚禮上瓤檐,老公的妹妹穿的比我還像新娘。我一直安慰自己娱节,他們只是感情好挠蛉,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著肄满,像睡著了一般谴古。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上稠歉,一...
    開(kāi)封第一講書(shū)人閱讀 49,741評(píng)論 1 289
  • 那天掰担,我揣著相機(jī)與錄音,去河邊找鬼怒炸。 笑死带饱,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的阅羹。 我是一名探鬼主播纠炮,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼月趟,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了恢口?” 一聲冷哼從身側(cè)響起孝宗,我...
    開(kāi)封第一講書(shū)人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎耕肩,沒(méi)想到半個(gè)月后因妇,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡猿诸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年婚被,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梳虽。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡址芯,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出窜觉,到底是詐尸還是另有隱情谷炸,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布禀挫,位于F島的核電站旬陡,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏语婴。R本人自食惡果不足惜描孟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望砰左。 院中可真熱鬧匿醒,春花似錦、人聲如沸缠导。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)酬核。三九已至,卻和暖如春适室,著一層夾襖步出監(jiān)牢的瞬間嫡意,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工捣辆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蔬螟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓汽畴,卻偏偏與公主長(zhǎng)得像旧巾,于是被迫代替她去往敵國(guó)和親耸序。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

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