作者:
綠盟科技
·
2014/11/26 10:09
0×00 簡述
來自CVE的漏洞描述:
data:image/s3,"s3://crabby-images/a8544/a8544dd8087ab550afa1b358681de5e1e9f928fd" alt="enter image description here"
測試環境: Win7 SP1 + Flash ActiveX 15.0.0.167
0×01 漏洞利用分析
介紹有關漏洞關鍵程式碼前,先看一下heap spray後的記憶體佈局:
data:image/s3,"s3://crabby-images/291df/291dfcde967d5be9e6e28342e3f84037afa86fb2" alt="enter image description here"
簡單描述為:
data:image/s3,"s3://crabby-images/5fa92/5fa92a8fe43ad37b4fd613c40bf2e214b92c5cdd" alt="enter image description here"
漏洞致使Uint Vector的length欄位被改寫。
漏洞關鍵程式碼:
data:image/s3,"s3://crabby-images/eec57/eec578c884a69980ccd531fbe8e2555b35ee9729" alt="enter image description here"
紅線標註的部分其操作流程:
取預定大小0×1000的ByteArray物件_loc3,賦值給domainMemory,以便casi32函式操作此記憶體
預置大小0×1000的ByteArray物件:
data:image/s3,"s3://crabby-images/29678/296780c3f7090c858fb051176510073fb24837ff" alt="enter image description here"
透過函式atomicCompareAndSwapLength將_loc3長度置0
casi32函式內由於整數溢位造成執行流改變,致使向_loc3偏移0×1000處成功寫入0×40000001
上述過程細節:
data:image/s3,"s3://crabby-images/38990/38990ce3fe62fafa16f42e27cd76f3a9a9d65521" alt="enter image description here"
data:image/s3,"s3://crabby-images/cff54/cff541ed6a46e83243337e32a2a844f24100ce92" alt="enter image description here"
data:image/s3,"s3://crabby-images/0a20d/0a20d3aa317687759838ed2760dbecaa618a46c9" alt="enter image description here"
data:image/s3,"s3://crabby-images/2266c/2266c75b2b1749553d4bb6d7651a1d25bc27aba3" alt="enter image description here"
這樣就可以以超長的Uint Vector為起點,讀取預置的物件資料。
利用關鍵點:
搜尋預置的sound物件進而計算出flash控制元件基址
預置的sound物件包含於噴射的少量Vector Object裡,這裡稱之為vec_3。
具體的噴射程式碼:
data:image/s3,"s3://crabby-images/5b90c/5b90c533bed21e40fbe5c178bd75042645d4ca02" alt="enter image description here"
透過特徵比對遍歷以獲取vec_3中元素:
data:image/s3,"s3://crabby-images/7c50e/7c50e4ac59c595e1271d536979b1674a0cea62c6" alt="enter image description here"
搜尋到的其中一項:
計算flash控制元件基址:
data:image/s3,"s3://crabby-images/72f05/72f05d2718af13ce3d1fe7381de41140b5e18bc7" alt="enter image description here"
在flash控制元件基址基礎上獲取rop鏈所需指令,用VirtualAlloc分配可執行記憶體過DEP。
data:image/s3,"s3://crabby-images/da81a/da81a45e9961ae8d10dc3a28cd101188f6794159" alt="enter image description here"
data:image/s3,"s3://crabby-images/3ac1a/3ac1a4def3b04ed4abf621a7dd197404d95876d2" alt="enter image description here"
構造rop鏈(部分):
data:image/s3,"s3://crabby-images/86e2e/86e2e0713631e7a260646178666ad7eeaaccb080" alt="enter image description here"
修改sound物件虛表指標,並呼叫修改後的虛表函式將執行流導向stack pivot。
data:image/s3,"s3://crabby-images/77502/7750225b2582c3b37f96a5ded833c791dac3b252" alt="enter image description here"
sound物件虛表指標修改前後:
data:image/s3,"s3://crabby-images/65002/650025401fd2eb9840eac2c958cdf3224bb82ccb" alt="enter image description here"
data:image/s3,"s3://crabby-images/e207f/e207fb038d94dba8ecfd1ad59820b037deebb273" alt="enter image description here"
修改後的虛表指標指向內容:
data:image/s3,"s3://crabby-images/d7dac/d7dac6453cb359b3f4d19ceeb629672466735297" alt="enter image description here"
呼叫虛擬函式觸發利用。
data:image/s3,"s3://crabby-images/08456/08456454a0fcfa1ac008c05f592a2d6ac2696dcb" alt="enter image description here"
0×02 分析總結
完整的利用至少由兩部分組成(html + swf),其中swf並不能獨立執行,需要html傳入的引數(shellcode),只拿到swf並不能獲知攻擊者的意圖。
0×03 參考文章
CVE-2014-0569漏洞分析
Cracking the CVE-2014-0569 nutshell
本文章來源於烏雲知識庫,此映象為了方便大家學習研究,文章版權歸烏雲知識庫!