zapline 发表于 2010-2-20 01:05

添加区段工具(AddSection)的编写

本帖最后由 zapline 于 2010-2-20 02:06 编辑

功能:为指定PE文件添加一个指定大小指定名称的区段。(添加成功率有待提高,欢迎各位指点)

运行界面:


为程序添加区段,我把它分为如下几步:

第一步,获取部分需要的PE信息(包括DOS头,NT头,最后一个区段头,文件和区段对齐颗粒大小)
f.Open(m_FileName,CFile::modeReadWrite);
f.Read(&dh,sizeof(IMAGE_DOS_HEADER));
f.Seek(dh.e_lfanew,CFile::begin);
f.Read(&nh,sizeof(IMAGE_NT_HEADERS));
SectionNum = nh.FileHeader.NumberOfSections;
f.Seek(sizeof(IMAGE_SECTION_HEADER) * (SectionNum-1), CFile::current);
f.Read(&sh,sizeof(IMAGE_SECTION_HEADER));
FileAlign = nh.OptionalHeader.FileAlignment;
SectionAlign = nh.OptionalHeader.SectionAlignment;

第二步,设置新区段的属性

Size = atoi(m_SectionSize);
NewSection.PointerToRelocations = 0;
NewSection.NumberOfRelocations = 0;
NewSection.PointerToLinenumbers = 0;
NewSection.NumberOfLinenumbers = 0;
NewSection.Characteristics = IMAGE_SCN_MEM_EXECUTE|IMAGE_SCN_MEM_READ|IMAGE_SCN_MEM_WRITE;
NewSection.SizeOfRawData = (Size%FileAlign?FileAlign*(Size/FileAlign+1):Size);
NewSection.PointerToRawData = sh.PointerToRawData + sh.SizeOfRawData;
NewSection.Misc.VirtualSize = Size;
if (sh.SizeOfRawData % SectionAlign)
{
VirtualSize = SectionAlign * (sh.SizeOfRawData/SectionAlign+1);
}
else
{
VirtualSize = sh.SizeOfRawData;
}
NewSection.VirtualAddress = sh.VirtualAddress + VirtualSize;
temp.Format("%8s",m_SecthionName);
for (n=0;n<8;n++)
{
NewSection.Name = temp.GetAt(n);
}


第三步,修改NT头(修改区段数,文件大小)
nh.FileHeader.NumberOfSections++;
nh.OptionalHeader.SizeOfImage += Size;
f.Seek(dh.e_lfanew,CFile::begin);
f.Write(&nh,sizeof(IMAGE_NT_HEADERS));

第四步,增加区段信息

f.Seek(dh.e_lfanew+sizeof(IMAGE_NT_HEADERS32)+sizeof(IMAGE_SECTION_HEADER)*SectionNum, CFile::begin);
f.Write(&NewSection,sizeof(IMAGE_SECTION_HEADER));


第五步,增加区段

f.Seek(NewSection.PointerToRawData,CFile::begin);
LPBYTE pData = new BYTE;
f.Write(pData,NewSection.SizeOfRawData);
delete pData;


可执行文件+源码:

ps520 发表于 2010-2-20 01:22

貌似没说写入数据的事
前排支持

zapline 发表于 2010-2-20 01:25

貌似没说写入数据的事
前排支持
ps520 发表于 2010-2-20 01:22 http://www.52pojie.cn/images/common/back.gif


    请听下回分解 (为PE文件添加消息框或者弹出网页)

wuhanqi 发表于 2010-2-20 01:51

...期待下回

henry3700 发表于 2010-2-20 02:31

虽然我是小菜菜,但是我会努力学习的!!

ximo 发表于 2010-2-20 12:59

丢出来吧,支持下小Z。
http://www.52pojie.cn/thread-34366-1-8.html

wodecaoxin 发表于 2010-2-20 13:07

学习PE好帮手啊

shayu 发表于 2010-2-21 00:09

支持下回分析 嘿嘿 写网页弹框框顶

ithurricane 发表于 2010-2-21 09:42

期待下一回,和加壳的教程啊~~~

chenchuai 发表于 2010-4-18 00:24

功能再多点就好了................
页: [1] 2 3
查看完整版本: 添加区段工具(AddSection)的编写