当前位置: 首页 > news >正文

6.PE文件新增节

PE文件新增节,需要完成以下几个步骤。

1)添加一个新的节表元素(可以copy一份)
2)在新增节后面填充一个节大小的0x00(大小为40个字节,也就是说要新增节表,必须要在SizeOfHeader后面必须有80个字节的空间才能新增节,如果不够,则需要抬高PE文件头)
3)像改PE头中节的数量
4)修改SizeOfImage的大小
5)在原有数据的最后,新增一个节的数据(内存对齐的整数倍).
6)修正新增节表的属性

核心代码如下:

/*
 * 添加节表
 * buff 拉伸状态的文件数据
 * return 增加成功还是失败
 */
char* addSection(char* buff, DWORD buffSize)
{
    PIMAGE_DOS_HEADER dosHeader = (PIMAGE_DOS_HEADER)buff;
    PIMAGE_NT_HEADERS ntHeader = (PIMAGE_NT_HEADERS)(buff + dosHeader->e_lfanew);
    /*
     * 一:将PE头和节表移到DOS头后面,防止添加不上节表
     * 1.申请同样大小的内存,并初始化为0
     * 2.将数据拷贝到临时内存中,并将原来的数据清空
     * 3.将e_lfanew指向0x40
     * 4.将数据拷贝到0x40后面
     * 5.释放内存
     */
    DWORD size = sizeof(ntHeader->Signature) + sizeof(ntHeader->FileHeader) + ntHeader->FileHeader.SizeOfOptionalHeader + (ntHeader->FileHeader.NumberOfSections * 0x28);
    char* ntHeaderAndSectionHeaderBuf = new char[size];
    memset(ntHeaderAndSectionHeaderBuf, 0x00, size);
    memcpy(ntHeaderAndSectionHeaderBuf, buff + dosHeader->e_lfanew, size);
    memset(buff + dosHeader->e_lfanew, 0x00, size);
    dosHeader->e_lfanew = 0x40;
    memcpy(buff + dosHeader->e_lfanew, ntHeaderAndSectionHeaderBuf, size);
    delete[] ntHeaderAndSectionHeaderBuf;
    ntHeaderAndSectionHeaderBuf = nullptr;
    ntHeader = (PIMAGE_NT_HEADERS)(buff + dosHeader->e_lfanew);

    /*
     * 增加节表,并修复里面的参数
     */
    PIMAGE_SECTION_HEADER newSectionHeader = (PIMAGE_SECTION_HEADER)(buff + dosHeader->e_lfanew + size);
    PIMAGE_SECTION_HEADER preSectionHeader = newSectionHeader - 1;
    // 设置节表名
    newSectionHeader->Name[0] = '.';
    newSectionHeader->Name[1] = 'f';
    newSectionHeader->Name[2] = 'g';
    newSectionHeader->Name[3] = 'c';
    newSectionHeader->Name[4] = 's';
    // 修复虚拟大小
    newSectionHeader->Misc.VirtualSize = 0x1000;
    // 修复虚拟地址
    newSectionHeader->VirtualAddress = preSectionHeader->VirtualAddress + preSectionHeader->SizeOfRawData;
    // 修复文件大小
    newSectionHeader->SizeOfRawData = 0x1000;
    // 修复文件地址
    newSectionHeader->PointerToRawData = preSectionHeader->PointerToRawData + preSectionHeader->SizeOfRawData;
    // 修复权限(我用的软件默认是.text这个,如果有其他情况,请自行适配)
    newSectionHeader->Characteristics = (newSectionHeader - ntHeader->FileHeader.NumberOfSections)->Characteristics;

    /*
     * 修改SizeOfImage以及numberOfSections
     */
    ntHeader->OptionalHeader.SizeOfImage += 0x1000;
    ntHeader->FileHeader.NumberOfSections++;

    /*
     * 增加节区,我里默认增加0x1000
     */
    char* newBuff = new char[buffSize + 0x1000];
    memcpy(newBuff, buff, buffSize);
    memset(newBuff + buffSize, 0x20, 0x1000);
    delete[] buff;
    buff = nullptr;
    return newBuff;
}

看效果:

练手软件及代码,需要的自取:

百度网盘 请输入提取码百度网盘为您提供文件的网络备份、同步和分享服务。空间大、速度快、安全稳固,支持教育网加速,支持手机端。注册使用百度网盘即可享受免费存储空间https://pan.baidu.com/s/1bpFzbCPZQ86_J0PzwN_YfA

提取码:st6t

相关文章:

  • Linux进程1.0--task_struct
  • 分支与循环(上)
  • OpenCV基础【图像和视频的加载与显示】
  • 超声重建,3D重建 超声三维重建,三维可视化平台 UR 3D Reconstruction
  • 链表·简单归并
  • 基于SpringBoot+Vue的毕业论文管理系统+LW示例参考
  • Vue:Vue+TS学习笔记
  • Linux第三次练习
  • 【后端】【django】【related_name】`related_name` 的作用
  • 召回度、准确度
  • Java基础面经
  • PyTorch 深度学习实战(14):Deep Deterministic Policy Gradient (DDPG) 算法
  • 【推荐项目】052-用水监控管理系统
  • 【Godot】Window类
  • 【SpringMVC】常用注解:@CookieValue
  • 股票查询系统
  • C#生产型企业ERP系统管理软件PCB行业ERP进销存MRP管理系统BOM管理
  • python---序列 (str,list,tuple)
  • RBAC 模型的简单实现
  • Mamba组件:状态空间模型简介
  • 中美瑞士会谈后中国会否取消矿产出口许可要求?外交部回应
  • 尹锡悦涉嫌发动内乱案举行第三次庭审
  • 西藏日喀则市拉孜县发生5.5级地震,震源深度10千米
  • 外交部:愿同拉美国家共同维护多边贸易体制
  • 美国再工业化进程需要中国的产业支持
  • AI药企英矽智能第三次递表港交所:去年亏损超1700万美元,收入多数来自对外授权