【網(wǎng)絡(luò)安全】Xred蠕蟲再分析及修復(fù)工具編寫

image.png

這個(gè)病毒很老了,已經(jīng)有很多前輩分析過該病毒,跟著前輩們的思路深入分析一下戳晌,并編寫一個(gè)清理工具。這是我分析的第一個(gè)真實(shí)環(huán)境下的惡意樣本痴柔,文中如果有不正確的地方請(qǐng)指正。只需要清理工具的話疫向,直接下滑到
解決方案 一節(jié)咳蔚。

病毒行為總覽

代碼使用Delphi7編寫,后續(xù)分析匯編代碼發(fā)現(xiàn)有對(duì)XP系統(tǒng)和更高版本windows做了兼容處理搔驼,在這些系統(tǒng)上都可以正確感染谈火,年代久遠(yuǎn)(我還沒用過xp..)。被感染機(jī)器的 C:\ProgramData\目錄下會(huì)有Synaptics目錄舌涨,其下包含原始的惡意樣本糯耍,但是圖標(biāo)不固定(圖標(biāo)會(huì)更新為最近一次運(yùn)行被感染exe文件的圖標(biāo)),病毒生成的大部分文件都將其設(shè)置為 隱藏文件和系統(tǒng)文件(Exlporer設(shè)置顯示隱藏文件和系統(tǒng)文件或命令行下attrib即可看到)囊嘉。


在這里插入圖片描述

被感染機(jī)器的Desktop温技、Documents、Downloads目錄下的32位EXE文件和xlsx文件都會(huì)被掉包扭粱,但是用戶并不會(huì)有察覺舵鳞,導(dǎo)致文件分享給他人時(shí),大范圍感染琢蛤。

病毒包含很多模塊蜓堕,下面是一個(gè)大體功能圖,其中和網(wǎng)絡(luò)連接有關(guān)的模塊的IOC都已經(jīng)失效博其。

在這里插入圖片描述

→點(diǎn)擊獲取網(wǎng)絡(luò)安全資料·攻略←

2000多本網(wǎng)絡(luò)安全系列電子書
網(wǎng)絡(luò)安全標(biāo)準(zhǔn)題庫資料
項(xiàng)目源碼
網(wǎng)絡(luò)安全基礎(chǔ)入門套才、Linux、web安全慕淡、攻防方面的視頻
網(wǎng)絡(luò)安全學(xué)習(xí)路線圖

蠕蟲模塊分析

通過 SHGetSpecialFolderLocation和
SHGetPathFromIDListA來獲取要感染的目錄(清理工具的編寫也會(huì)通過這種方式)背伴。病毒會(huì)獲取Desktop、Downloads和Documents的路徑并遞歸感染子文件。

在這里插入圖片描述

EXE文件感染分析

對(duì)于EXE文件挂据,通過LoadLibrary加載到當(dāng)前進(jìn)程(病毒是32位的,所以只感染32位的EXE)以清,根據(jù)其資源節(jié)“EXEVSNX”的情況,來進(jìn)行對(duì)應(yīng)的操作崎逃,這個(gè)資源節(jié)內(nèi)的數(shù)據(jù)代表著版本號(hào)掷倔。這個(gè)病毒是可以進(jìn)行版本更新的。


在這里插入圖片描述

具體的感染流程如下个绍,思路很簡單勒葱。將原文件打包到病毒文件的資源節(jié)“EXERESX”中,病毒文件的圖標(biāo)被替換為原文件的圖標(biāo)巴柿,最后用病毒文件替換原文件凛虽。


在這里插入圖片描述

在這里插入圖片描述

當(dāng)用戶運(yùn)行被掉包的EXE文件時(shí),會(huì)釋放出資源節(jié)"EXERESX"的原文件并運(yùn)行广恢,這樣就對(duì)用戶來說無感知凯旋。

具體的釋放流程如下,原文件會(huì)被釋放到已 ".cache"開頭的文件中钉迷,文件屬性被設(shè)置為 系統(tǒng)文件和隱藏文件至非,即使打開“顯示隱藏文件的選項(xiàng)”也不會(huì)顯示,“顯示系統(tǒng)文件”的選項(xiàng)一般用戶很少會(huì)打開糠聪。比較有趣的一點(diǎn)是代碼中還會(huì)判斷 ".cache"開頭的文件是否也有資源節(jié)"EXERESX"荒椭。這是一個(gè)重復(fù)感染的問題,病毒作者考慮到了這一點(diǎn)舰蟆。分析整個(gè)代碼來看趣惠,可以發(fā)現(xiàn)病毒作者的編程功底很強(qiáng),很多特殊情況的處理都有考慮到身害。

在這里插入圖片描述
在這里插入圖片描述

XLSX文件感染分析

感染xlsx文件是通過COM組件完成的味悄,所以只有安裝了Excel的機(jī)器才會(huì)被正確感染(清理工具也是利用COM組件來進(jìn)行修復(fù)xlsx文件的)。


在這里插入圖片描述

大致的感染流程如下题造,病毒文件的資源節(jié)"XLSM"包含包含了惡意宏代碼的xlsm文件傍菇。


在這里插入圖片描述

中間部分大量調(diào)用了COM組件中的函數(shù),這里并沒有去分析界赔。用動(dòng)態(tài)調(diào)試跳過了這些函數(shù)丢习,從結(jié)果來看就是把原來的xlsx中的數(shù)據(jù)拷貝到包含宏代碼的xlsm文件中。最后替換原了的xlsx文件淮悼,并再起目錄下生成一個(gè) "~$chac1"文件(這也是一個(gè)感染特征咐低,文件夾下有這個(gè)文件說明該路徑下的xlsx文件都被感染為xlsm文件),這個(gè)文件的數(shù)據(jù)就是病毒文件本身袜腥,文件屬性也設(shè)置了系統(tǒng)文件和隱藏文件见擦。被感染的xlsx文件后綴會(huì)變成xlsm钉汗,內(nèi)容和原來一樣。
在這里插入圖片描述

其它模塊分析

這些模塊有的已經(jīng)失效了鲤屡,并沒有太深入的分析损痰。

  • 郵件發(fā)送: 使用的是Delphi中封裝好的庫,使用郵件服務(wù)器是
    smtp.gmail.com,賬號(hào)密碼是xredline2@gmail.com;xredline3@gmail.com/xredline2x;xredline3x
    我用gmail登錄了一下酒来,已經(jīng)失效了卢未。發(fā)送郵件的目的郵箱地址是 xredline1@gmail.com
    在這里插入圖片描述
  • 鍵盤記錄,設(shè)置消息鉤子堰汉,最常用的方式辽社。dll文件在病毒文件資源節(jié)"KBHKS"中。(動(dòng)態(tài)調(diào)試過程中消息鉤子并沒有設(shè)置翘鸭,出錯(cuò)原因還有待確認(rèn))
在這里插入圖片描述
  • 遠(yuǎn)控模塊滴铅,功能很少,反彈shell就乓、屏幕截圖汉匙、文件上下載...
  • 自啟動(dòng)項(xiàng),直接操作注冊(cè)表档址,用的是Delphi封裝好的庫(Register),使用很簡單盹兢,不贅述。

IOC整理

文件MD5就不貼了守伸,被感染文件一直都是變化的。


在這里插入圖片描述

在這里插入圖片描述

解決方案

基于上面的分析浦妄,就可以編寫修復(fù)工具了尼摹。工具使用的也是Delphi編寫的,為了分析這個(gè)病毒剂娄,稍微了解了一下Delphi蠢涝,正好Delphi提供了一個(gè)很方便使用圖形界面庫。cdj68765 前輩也提供了一個(gè)命令行版本的修復(fù)工具阅懦,是用 c#寫的和二。對(duì)于把xlsm修復(fù)為xlsx,前輩使用了Open_XML_SDK進(jìn)行修復(fù)耳胎,這種方式更好惯吕。我使用的是和惡意代碼一樣的方式(COM組件)進(jìn)行修復(fù),這是一個(gè)取巧的方式怕午,但是因?yàn)閤lsm中的VBProject被加密了废登,導(dǎo)致通過COM組件的方式無法讀取到宏代碼進(jìn)行特征判斷后再修復(fù),這里用到了一個(gè)折中的方案進(jìn)行特征判斷郁惜,下面會(huì)說明堡距。

代碼和工具下載在這里:https://github.com/forTheBest12138/RepairerForXredWorm

清理效果如下,目前只會(huì)掃描 Desktop、Downloads羽戒、Documents目錄及其子目錄缤沦。如果不在這些目錄下的文件可以手動(dòng)輸入進(jìn)行修復(fù),目錄和文件路徑都行易稠。


在這里插入圖片描述

代碼修復(fù)思路說明:

  1. 尋找病毒進(jìn)程并關(guān)閉缸废,這邊病毒開機(jī)啟動(dòng)后一直后臺(tái)運(yùn)行
  2. 清除自啟動(dòng)項(xiàng),及其對(duì)應(yīng)的文件
  3. 修復(fù)EXE文件缩多,判斷標(biāo)準(zhǔn)是 EXE文件是否包含EXEVSNX和 EXERESX資源節(jié)呆奕,原理很簡單,不贅述。
在這里插入圖片描述

修復(fù)XLSX文件兔港,使用COM組件的方式其實(shí)就和手動(dòng)用Excel進(jìn)行操作是一樣的栈源。所以我的思路是將xlsm"另存為/SaveAs"為xlsx格式,就會(huì)直接剔除掉宏代碼姆泻,就和手動(dòng)用Excel將xlsm保存為xlsx的效果是一樣的,對(duì)應(yīng)的代碼就是圖中標(biāo)號(hào)3的地方冒嫡。有幾個(gè)坑點(diǎn)拇勃,圖中標(biāo)號(hào)1處的代碼表示打開xlsm文件時(shí)是否執(zhí)行宏代碼,默認(rèn)為1孝凌,即執(zhí)行方咆,所以一定要設(shè)置成3!s凹堋瓣赂!這個(gè)選項(xiàng)好像不受宏執(zhí)行策略的影響。標(biāo)號(hào)2處的代碼是來判斷xlsm的宏代碼中是否有特定的字符串片拍,這樣就可以先進(jìn)行特征匹配判斷其是否是被感染的xlsm文件煌集,再進(jìn)行修復(fù),但是因?yàn)閤lsm文件中的VBProject被加密捌省,無法讀取到宏代碼苫纤。所以這部分代碼無法使用,上面提到的折中的方案就是判斷VBProject是否被加密再進(jìn)行修復(fù)纲缓。所以特殊情況就是一個(gè)正常的xlsm文件有被加密的VBProject就會(huì)被誤認(rèn)為是被感染的文件卷拘!如果用Open_XML_SDK的話是可以繞過加密的問題,這樣就可以達(dá)到100%的修復(fù)準(zhǔn)確率色徘。

在這里插入圖片描述

同時(shí)還要設(shè)置運(yùn)行訪問VBA對(duì)象模型的注冊(cè)表項(xiàng)恭金,否則代碼是無權(quán)讀取xlsm的宏代碼的。
在這里插入圖片描述

感染過程中生成的".cache"前綴文件和“~$cache1"文件也會(huì)清理掉褂策。
在這里插入圖片描述

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末横腿,一起剝皮案震驚了整個(gè)濱河市颓屑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌耿焊,老刑警劉巖揪惦,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異罗侯,居然都是意外死亡器腋,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門钩杰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來纫塌,“玉大人,你說我怎么就攤上這事讲弄〈胱螅” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵避除,是天一觀的道長怎披。 經(jīng)常有香客問我,道長瓶摆,這世上最難降的妖魔是什么凉逛? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮群井,結(jié)果婚禮上状飞,老公的妹妹穿的比我還像新娘。我一直安慰自己书斜,他們只是感情好昔瞧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著菩佑,像睡著了一般。 火紅的嫁衣襯著肌膚如雪凝化。 梳的紋絲不亂的頭發(fā)上稍坯,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音搓劫,去河邊找鬼瞧哟。 笑死,一個(gè)胖子當(dāng)著我的面吹牛枪向,可吹牛的內(nèi)容都是我干的勤揩。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼秘蛔,長吁一口氣:“原來是場噩夢啊……” “哼陨亡!你這毒婦竟也來了傍衡?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤负蠕,失蹤者是張志新(化名)和其女友劉穎蛙埂,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體遮糖,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绣的,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了欲账。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片屡江。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖赛不,靈堂內(nèi)的尸體忽然破棺而出惩嘉,到底是詐尸還是另有隱情,我是刑警寧澤俄删,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布宏怔,位于F島的核電站,受9級(jí)特大地震影響畴椰,放射性物質(zhì)發(fā)生泄漏臊诊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一斜脂、第九天 我趴在偏房一處隱蔽的房頂上張望抓艳。 院中可真熱鬧,春花似錦帚戳、人聲如沸玷或。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽偏友。三九已至,卻和暖如春对供,著一層夾襖步出監(jiān)牢的瞬間位他,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來泰國打工产场, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鹅髓,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓京景,卻偏偏與公主長得像窿冯,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子确徙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

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