吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 12527|回复: 22
收起左侧

[其他原创] 添加区段工具(AddSection)的编写

[复制链接]
zapline 发表于 2010-2-20 01:05
本帖最后由 zapline 于 2010-2-20 02:06 编辑

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

运行界面:
未命名.jpg

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

第一步,获取部分需要的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[n] = 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[NewSection.SizeOfRawData];
f.Write(pData,NewSection.SizeOfRawData);
delete pData;

可执行文件+源码:

Release.rar (157.33 KB, 下载次数: 321) AddSection.rar (225.41 KB, 下载次数: 282)

免费评分

参与人数 1威望 +1 收起 理由
wgz001 + 1 最近高产了

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

ps520 发表于 2010-2-20 01:22
貌似没说写入数据的事
前排支持
 楼主| zapline 发表于 2010-2-20 01:25
貌似没说写入数据的事
前排支持
ps520 发表于 2010-2-20 01:22



    请听下回分解 (为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
功能再多点就好了................
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则 警告:本版块禁止灌水或回复与主题无关内容,违者重罚!

快速回复 收藏帖子 返回列表 搜索

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-5-15 15:08

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表