版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
Pe文件實現(xiàn)信息隱藏
馮紹東
主要內(nèi)容:PE文件結(jié)構(gòu)
原理
實現(xiàn)
上述算法的一點改進
小結(jié)
一PE文件結(jié)構(gòu)
PE文件框架構(gòu)成
DOSMZheader
DOSstub
PEheader
Sectiontable
Section1
Section2
Section...
SectionnPE文件結(jié)構(gòu)的總體層次分布。
DOSMZheader
DOSstub所有PE文件(甚至32位的DLLs)必須以一個簡單的DOSMZheader開始,在偏移0處有DOS下可執(zhí)行文件的“MZ標志”,有了它,一旦程序在DOS下執(zhí)行,DOS就能識別出這是有效的執(zhí)行體,然后運行緊隨MZheader之后的DOSstub。DOSstub實際上是個有效的EXE,在不支持PE文件格式的操作系統(tǒng)中,它將簡單顯示一個錯誤提示,類似于字符串"ThisprogramcannotruninDOSmode"或者程序員可根據(jù)自己的意圖實現(xiàn)完整的DOS代碼。通常DOSstub由匯編器/編譯器自動生成,對我們的用處不是很大,它簡單調(diào)用中斷21h服務(wù)9來顯示字符串"ThisprogramcannotruninDOSmode"。
節(jié)表(Section):typedef
struct_IMAGE_SECTION_HEADER{
BYTE
Name[IMAGE_SIZEOF_SHORT_NAME];//節(jié)表名稱,如“.text”
union{
DWORD
PhysicalAddress;//物理地址
DWORD
VirtualSize;//真實長度
}Misc;
DWORD
VirtualAddress
;//RVA
DWORD
SizeOfRawData;//物理長度
DWORD
PointerToRawData;//節(jié)基于文件的偏移量
DWORD
PointerToRelocations;//重定位的偏移
DWORD
PointerToLinenumbers;//行號表的偏移
WORD
NumberOfRelocations;//重定位項數(shù)目
WORD
NumberOfLinenumbers;//行號表的數(shù)目
DWORD
Characteristics;//節(jié)屬性
}
可用空間=SizeOfRawData(物理長度)-VirtualSize(真實長度)二原理
(1) PE文件由于使用高級語言編寫的,存在大量的冗余,我們需要做的是在不影響程序執(zhí)行的基礎(chǔ)上把我們的資料存放到那些程序沒用到的空間。我們可在上邊的節(jié)表中發(fā)現(xiàn)SizeOfRawData,VirtualSize,一個是物理長度,一個是實際長。SizeOfRawData-VirtualSize就是我們可利用的空間。我們只要找到這段空間的起始地址就行了。而PointerToRawData就是我們要的,這樣問題都解決了。剩下的只是編程實現(xiàn)了。另外,除了段空間可利用外,文件頭也有一大段的空間可用,CIH病毒就是利用它隱藏自己的。 為了加強隱密性,我們需要把VirtualSize的值改為VirtualSize+加入該段的長度。而這會導(dǎo)致后來還原不回來,所以要在文件中加入一段特殊的字符串,這樣在還原時根據(jù)該字符串得到隱藏資料的起點。在程序中特殊字符串即用戶輸入的密碼。這樣不知道密碼者就不容易獲得其中隱藏資料。原理(2)
段隱藏空間段程序占用空間可利用空間段首地址PointerToRawData真實長度VirtualSize物理長度SizeOfRawData原理(3)
PE文件頭隱藏空間PE文件頭第一段的PointerToRawData
DOSMZheader
DOSstub
PEheader
Sectiontable
可利用空間(大約3kb,CIH病毒利用此空間)三實現(xiàn)
首先獲得pe文件頭的信息獲得段的信息寫文件,實現(xiàn)信息隱藏獲得pe文件頭的信息Voidgetpeheader(CStringfilename){
CFile
cf;
cf.Open(filename,CFile::modeRead);
cf.ReadHuge(&dos_head,sizeof(IMAGE_DOS_HEADER)); cf.Seek(dos_head.e_lfanew,0);
cf.ReadHuge(&signature,sizeof(DWORD));
cf.ReadHuge(&_head,sizeof(IMAGE_FILE_HEADER));
cf.ReadHuge(&opt_head,sizeof(IMAGE_OPTIONAL_HEADER));
cf.Close();}獲得段的信息Voidgetsection(Cstringfilename){
CFile
cf;
cf.Open(filename,CFile::modeRead);
longsecpos= sizeof(IMAGE_DOS_HEADER)+dos_head.e_lfanew+ sizeof(DWORD)+sizeof(IMAGE_FILE_HEADER) +sizeof(IMAGE_OPTIONAL_HEADER); cf.Seek(secpos,0); for(intI=0;I<_head.NumberOfSections;I++)
cf.ReadHuge(§ion_header[I],sizeof(IMAGE_OPTION AL_HEADER));
cf.Close();}程序中段的總數(shù)段表位置寫文件,實現(xiàn)信息隱藏Voidwritefile(Cstringfilename,intsection){ CFile
cf; cf.Open(filename,CFile::modeWrite); if((section_header[section].SizeOfRawData- section_header[section].Misc.VirtualSize)<=0) { cf.Close(); return; } cf.Seek(section_header[section].PointerToRawData+ section_header[section].VirtualSize,0); longI=0; charch; while(I<section_header[section].SizeOfRawData- section_header[section].Misc.VirtualSize) { if((ch=mygetch()))cf.WriteHuge(&ch,1); I++; } cf.Close();}四上述算法的一點改進
為了增強保密性,最好在隱藏資料前對資料進行加密,如使用rijnaedl等算法為了能檢測出,資料是否被修改,可以采取校驗位方法詳細做法參看程序源
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度員工股權(quán)激勵與員工持股平臺設(shè)立合作協(xié)議3篇
- 2024年中國櫥窗式百葉片換氣扇市場調(diào)查研究報告
- 2024年05月遼寧中國工商銀行遼寧分行校園招考筆試歷年參考題庫附帶答案詳解
- 2024年中國擋糧板市場調(diào)查研究報告
- 《關(guān)于車輛主動懸架穩(wěn)定性控制系統(tǒng)研究》
- 《芝麻油質(zhì)量安全(苯并芘)關(guān)鍵控制技術(shù)及生產(chǎn)工藝研究》
- 2024年廠區(qū)校園護欄項目可行性研究報告
- 2024年EVA保溫管項目可行性研究報告
- 2024年六位帶表排插座項目可行性研究報告
- 2024年武漢市漢南區(qū)中醫(yī)醫(yī)院高層次衛(wèi)技人才招聘筆試歷年參考題庫頻考點附帶答案
- 人教版六年級上冊數(shù)學(xué)第八單元數(shù)學(xué)廣角數(shù)與形單元試題含答案
- 2025年“三基”培訓(xùn)計劃
- 第20課 北洋軍閥統(tǒng)治時期的政治、經(jīng)濟與文化 教案
- 住房公積金稽核審計工作方案例文(4篇)
- Unit 2 My Schoolbag ALets talk(說課稿)-2024-2025學(xué)年人教PEP版英語四年級上冊
- 山東省青島實驗高中2025屆高三物理第一學(xué)期期末綜合測試試題含解析
- 物理人教版2024版八年級上冊6.2密度課件03
- 2024-2030年中國光纖傳感器行業(yè)競爭格局及發(fā)展趨勢分析報告
- 鐵路設(shè)備售后服務(wù)方案
- 2023年中國華電集團有限公司招聘考試真題
- 道路工程監(jiān)理實施細則
評論
0/150
提交評論