<<Mac OS 軟件安全與逆向分析>> 一

1.入門指令

jz指令:跳轉指令,可以理解成如果前面比較指令的比較結果相同則跳轉到指定的地址;
jnz指令:與jz指令正好相反,不相等則跳轉;
jmp指令:不管任何情況都會進行跳轉;
call指令:調用過程指令,一般對應高級語言中的函數調用

2.MacOS目錄結構

/usr/bin 目錄中存放著用戶安裝的命令行工具;
/etc 目錄存放著系統的配置信息;
/Applications 用用程序目錄,存放系統與用戶安裝的應用程序
/Library 系統應用的數據 和 文檔信息;
/Network 網絡鄰居虛擬目錄;
/System 只有一個 Library 子目錄,里面存放了系統運行的重要組件,如框架與內核模塊,系統內置的第三方程序;
/Users 所有用戶的主目錄;
/Volumes 可移動美圖,磁盤 dmg鏡像的掛載點

3.權限

MacOS 內置staff,wheel,admin三個用戶組,所有用戶組都屬于staff用戶組,該組提供了對當前用戶自己目錄的讀寫執行權限;
admin用戶組允許用戶通過sudo命令切換為root用戶,默認創建的用戶屬于admin;
wheel用戶組是root用戶組,只有uid為0 的root用戶才屬于該組.

4.系統調用

macOS系統實現了POSIX標準,并擴展了部分內容---加入了MACH-Trap,取名為xnu.
開源地址 : https://opensource.apple.com/source/xnu/

5.進程間通信

5.1 Mach端口(Mach Port)底層的進程間通信方式,消息發送方調用mach_msg_send()發送消息,消息指定了端口號,消息類型,及內容;接收方調用mach_msg_receive()接受指定端口的消息,上層CoreFoundation 提供了CFMachPort,及Foundation童工的NSMachPort對Mach端口進行封裝;
5.2 分布式通知(Distributed Notifications),NSDistributedNotificationCenter(注冊通知),NSDistributedNotification(接收通知),發送分布式通知,非常消耗資源,頻繁發送,應考慮其他方式;
5.3 NSConnection 注冊,接收;
5.4 XCP 使用最廣泛,NSXCPCConnection;

6.安全框架

6.1 CommonCrypto
6.2 Keychain

7.系統安全機制

7.1 FileVault macOS上的磁盤加密技術
7.2 代碼簽名 查看本機所有簽名證書security find-identity -v -p codesigning,簽名腳本codesign,查看軟件包簽名 codesign -d -vv 包名.app
7.3 codesign在簽名過程中會改寫可執行文件,在文件Load Commands中添加一個LC_CODE_SIGNATURE項,里面會寫入代碼簽名的一些信息.
7.4 程序包簽名與單獨的二進制簽名不同,程序包除了可執行文件還包含各種資源圖片,和不同語言的文件,程序包中的所有資源文件都會被簽名,并新建一個_CodeSignature/CodeResources的文件夾,其中存儲著所有文件的簽名Hash信息,其本質上就是一個Plist文件
7.5 對于編譯好且已經開啟PIE的程序,可以通過手動修改頭部flags值來去掉PIE屬性,從而達到關閉ASLR的目的,
github腳本:https://github.com/sskaje/disable_aslr/blob/master/disable_aslr.py
7.6 沙盒機制
7.7 Rootless 更少的root權限,又稱為SIP(System Intergrity Protection 系統完整性保護),通過Rootless系統可以決定即使第三方程序獲取了系統Root權限,也不能做一些事情,比如:文件系統保護,運行時保護,內核擴展限制.
7.8 Gatekeeper 守門人,當我們第一次運行Mac的時候,安裝從互聯網下載的軟件時,會提示,不是從AppStore下載的,不允許裝載,系統是怎么知道我們的軟件時從哪里下載的

從互聯網下載的程序會有一個 @ 標簽

yangpei1@localhost downLoad % ls -al
total 11907840
drwxr-xr-x  11 yangpei1  staff         352  9 23 10:38 .
drwxr-xr-x  31 yangpei1  staff         992  6 29 09:09 ..
-rw-r--r--@  1 yangpei1  staff        6148  8 18 16:30 .DS_Store
-rw-r--r--@  1 yangpei1  staff        6148  6 13 14:35 .DS_Store (1)
-rw-r--r--@  1 yangpei1  staff    96341959  9 23 10:38 MACOS軟件安全與逆向分析.pdf

8.代碼編譯

整個編譯過程如下:
1.檢查依賴(Check dependencies),
2.生成輔助文件(Write auxiliary files),
3.編譯(CompileC),
4.鏈接(Ld),
5.生成調試符號(Generate DSYMFile),
6.代碼簽名(CodeSign).

最后一步是代碼簽名,沒有指定簽名證書的情況下,Xcode默認使用adHoc簽名.

9.dyld動態庫的加載

1.設置運行環境,處理環境變量
2.初始化主程序
3.加載共享緩存
4.加載插入的動態庫
5.鏈接祝程序
6.鏈接插入動態庫
7.執行弱符號綁定
8.執行初始化方法
9.查找入口點并返回
dyld: 當Mach-O映像加載時,dyld首先會檢查該Mach-O映像與所需動態庫是否在共享緩存中,如果在,直接將它在共享緩存中的內存地址映射到進程的內存地址空間.

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,702評論 6 534
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,615評論 3 419
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,606評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,044評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,826評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,227評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,307評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,447評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,992評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,807評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,001評論 1 370
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,550評論 5 361
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,243評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,667評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,930評論 1 287
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,709評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,996評論 2 374