5月17日左右,微信群中出現(xiàn)了可使iOS版微信閃退的GIF表情。
5月26日傍晚,360安全研究員宋申雷對表示,微信知道這個漏洞兩周了,但是攔截策略依然不行,第一個crash出現(xiàn)時就對樣本做了hash 攔截,這都兩周了,改一個字節(jié)的版本都有多少個了。
此外,他還指出,現(xiàn)在不在原圖改字節(jié)了,直接把有漏洞的最后一幀構(gòu)造到任意的GIF中。
為了更好地促進(jìn)讀者了解其中的機(jī)制,360NirvanTeam對于此事件進(jìn)行了具體的技術(shù)分析。
一、背景情況
5月17日起,在各個微信群中流傳著一個天線寶寶的GIF表情。在iOS版的微信上,只要打開了包含這個GIF表情的聊天窗口,就會造成微信閃退。
在進(jìn)行具體分析之前,對崩潰原因進(jìn)行了猜測:(1)iOS系統(tǒng)自帶GIF解析功能存在問題;(2)微信自己實現(xiàn)GIF解析的功能,由于對輸入數(shù)據(jù)的校驗不嚴(yán)格,導(dǎo)致異常。
經(jīng)過測試,發(fā)現(xiàn)iOS版QQ不受影響,因此可以排除iOS的GIF解析問題。
二、原因分析
1、樣本精簡
初始的GIF樣本有1MB之多,不利于定位引起問題的具體數(shù)據(jù),因此我們需要對樣本進(jìn)行精簡。通過010 Editor打開原始樣本GIF,利用GIF模板解析,發(fā)生解析異常,這就表示樣本GIF的格式存在問題。
從模板解析的情況顯示,在38幀正常的圖片數(shù)據(jù)后,出現(xiàn)了異常的數(shù)據(jù)。如圖所示,因此我們將正常數(shù)據(jù)部分移除,僅保留異常數(shù)據(jù),進(jìn)行下一步精簡。
可以看到,剩余的異常數(shù)據(jù)的部分有10多萬個,通過二分法的方式進(jìn)行測試和排除。具體就是,刪除一半后,測試另外一半是否可以導(dǎo)致崩潰。
如果崩潰了,說明引起異常的數(shù)據(jù)在保留的一半中,反之則說明在刪除的部分中。
經(jīng)過不斷的排除后,發(fā)現(xiàn)異常的數(shù)據(jù)就在下圖的紫色部分中。只要帶有GIF的圖像數(shù)據(jù)部分帶有這些異常數(shù)據(jù),就會導(dǎo)致iOS微信閃退。
2、調(diào)試分析
經(jīng)過樣本精簡,我們已經(jīng)發(fā)現(xiàn)了引起異常的數(shù)據(jù)位置。那么,現(xiàn)在就需要結(jié)合實際的調(diào)試,來確定實際引起異常的數(shù)據(jù)。
以iOS微信6.5.7版為例,崩潰發(fā)生時的調(diào)用棧如下,崩潰發(fā)生于微信內(nèi)部,說明是微信自身的GIF解析功能存在問題。
經(jīng)過對相關(guān)函數(shù)的逆向分析,最終確定了引起異常的數(shù)據(jù)。首先來觀察sub_100B6CBF0這個函數(shù),對于GIF中的數(shù)據(jù)進(jìn)行循環(huán)查找,如果存在0x21和0xF9,那么當(dāng)前數(shù)據(jù)就表示是一個GraphicControlExtension結(jié)構(gòu),并接著對GraphicControlExtension數(shù)據(jù)進(jìn)行解析。
如果當(dāng)前查找到的數(shù)據(jù)為0x2C,就表示搜索到了一個ImageDescriptor,跳出while循環(huán),進(jìn)行實際圖片數(shù)據(jù)的解析。這里也就是異常數(shù)據(jù)的起始位置!
正常的幀數(shù)據(jù)的ImageDescriptor數(shù)據(jù)如下:
而引起異常的數(shù)據(jù)中,恰好存在0x2C這個關(guān)鍵的分隔符,導(dǎo)致下述紅框中的數(shù)據(jù)被解析成了一個ImageDescriptor??梢钥吹?,ImageWidth屬性為0,ImageHeight屬性為0x100。
接下來,這部分異常的數(shù)據(jù)就會進(jìn)入sub_100B6CE90函數(shù)進(jìn)行解析。由于ImageWidth為0,導(dǎo)致與ImageHeight相乘后等于0,在new buffer時,傳入的大小參數(shù)為0,這是第一個問題,但這并不會導(dǎo)致閃退,仍然可以分配一個很小的堆塊。
引起崩潰的代碼如下,在else block中,sub_100B6C4F0的作用沒有具體跟蹤,猜測是進(jìn)行l(wèi)zw解壓縮,并返回解壓縮后的數(shù)據(jù)長度v21。
由于v10 = 0x0000010000000000,截斷成unsigned int后為0,這就導(dǎo)致 v10 – 1 – v21 為負(fù)數(shù),作為memset第三個參數(shù),相應(yīng)的unsigned int形式就是一個很大的正數(shù)。在memset時,就會導(dǎo)致崩潰,這是第二個問題。
三、總結(jié)
這個問題的根本原因是微信實現(xiàn)了自己的GIF解析功能,但由于對輸入數(shù)據(jù)的校驗不嚴(yán)格,導(dǎo)致異常的數(shù)據(jù)被解析,引起崩潰。
在5月17日當(dāng)天,這個GIF開始流傳后,微信似乎在服務(wù)器端做了屏蔽,使得這個GIF無法被正常接收,但我們只要隨便修改一下GIF中的任意一個字節(jié),就能繞過這個屏蔽措施。
同時由于iOS應(yīng)用上架需要經(jīng)過蘋果審核,需要額外耗費一定時間,這就使得這個Bug即使修復(fù)后,所有用戶也無法立刻更新。
目前最新的iOS微信6.5.8版本仍然存在崩潰的問題。
責(zé)任編輯:海凡
- 韓軍阿帕奇直升機(jī)首次進(jìn)行實彈射擊 “地獄火”導(dǎo)彈厲害嗎?2017-11-14
- 坦桑尼亞一小學(xué)發(fā)生爆炸 至少5名學(xué)生死亡45人受傷2017-11-09
- 微信還信用卡怎么收費?超出5000元的部分按0.1%進(jìn)行收費2017-11-08
- 朝鮮最新消息 朝鮮否認(rèn)“核試驗場坍塌,致200多人死亡”報道2017-11-03
- 微信清理僵尸粉騙局是怎么回事?該怎樣安全的清理僵尸粉?2017-10-31
- 微信左右腦測試實為竊取信息 警方:勿輕易授權(quán)2017-10-31
- 世越號近況 世越號沉船仍有5名失蹤者 本月末后是否繼續(xù)搜索引關(guān)注2017-10-26
- 中國游戲逆襲韓國?伽馬數(shù)據(jù):2017出口將大增2017-10-26
- 微信QQ本月不能修改個人資料不能換頭像資料是因為系統(tǒng)維護(hù)嗎2017-10-19
- 好友發(fā)微信幫你免費清理僵尸粉?實為盜號詐騙2017-10-13
- 最新科技數(shù)碼 頻道推薦
-
被國產(chǎn)手機(jī)打趴!三星手機(jī)在國內(nèi)市場份額狂降2017-11-14
- 進(jìn)入圖片頻道最新圖文
- 進(jìn)入視頻頻道最新視頻
- 一周熱點新聞
已有0人發(fā)表了評論