校验和(Checksum)「建议收藏」

校验和(Checksum)「建议收藏」校验和(Checksum)PE的可选映像头(IMAGE_OPTION_HEADER)里面,有一个Checksum字段,是该文件的校验和,一般EXE文件可以使0,但一些重要的和系统DLL及驱动文件必须有

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

校验和(Checksum)

PE的可选映像头(IMAGE_OPTION_HEADER)里面,有一个Checksum字段,是该文件的校验和,一般EXE文件可以使0,但一些重要的和系统DLL及驱动文件必须有一个校验和.

Windows 提供了一个API函数MapFileAndCheckSum 测试文件的Checksum,它位于IMAGEHLP.DLL链接库里,其原型:

ULONG MapFileAndCheckSum

{

         LPSTR FileName,           // 文件名

         LPDWORD HeaderSum,     // 指向PE文件头的CheckSum

         LPDWORD new_checksum  // 指向新计算出的Checksum

}

程序一旦运行后,new_checksum 地址处将放当前的文件的校验和,old_checksum地址指向PE文件的checksum字段

安全的方法是将此值放在注册表里,需要时比较.

内存映像校验

磁盘文件完整性校验可以抵抗解密者直接修改文件,但对内存补丁却没有效果,必须对内存关键的代码进行校验.

1 对整个代码进行校验

每个程序至少有一个代码区块和数据区块,数据区块属性可读写,程序运行时全局变量通常会放在这里,这些数据会动态变化,因此校验这部分是没什么意义,而代码段只读,存放的是程序代码,在程序中数据数不会变的,因此用这部分进行内存校验是可行的.

具体实现方法:

(1) 从内存中映像中得到PE相关数据,如代码块的RVA和内存大小

(2) 根据得到代码区块的RVA值和内存大小,计算出内存数据的CRC-32值

(3) 读取自身文件先前存储的CRC-32值(PE文件头前一个字段),这个值是通过软件写进去的.

(4) 比较两个CRC-32值.

这样比较内存的代码段校验,只要内存的数据被修改,就能发现。

BOOL CodeSectionCRC32()

{

         PIMAGE_DOS_HEADER pDosHeader = NULL;

         PIMAGE_NT_HEADERS pNTHeader = NULL;

         PIMAGE_SECTION_HEADER pSection = NULL;

         DWORD ImageBase,OriginalCRC32;

        

         ImageBase = (DWORD)GetModuleHandle(NULL); // 取基址

         pDosHeader = (PIMAGE_DOS_HEADER)ImageBase;

         pNtHeader = (PIMAGE_NT_HEADER32)((DWORD)pDosHeader + pDosHeader -> e_lfanew);

// 定位到PE文件头前4个字节值,并读取存储在这里的CRC -32值

          OriginalCRC32 = *((DWORD*)(DWORD)pNtHeader – 4);

pSecHeader = IMAGE_FIRST_SECTION(pNtHeader);    // 得到第一个区块的地址

//假设第一个区块就是代码区块

if(OriginalCRC32 == CRC32((BYTE*)ImageBase + pSecHeader -> VirtualAddress)

// 为了方便加壳

// 上一句也可为if(OriginalCRC32 == CRC32((BYTE *)0x401000, 0x36AE)

return TRUE;

else

return FALSE;

}

2 检验代码片段

在实际过程中,有时只需对一小段代码进行内存校验,以防止调试工具INT3断点

下面是一段汇编代码

校验和(Checksum)「建议收藏」

翻译成VC

DWORD address1, address2,size;

_asm Mov address1, offset begindecryt;

_asm Mov address2,offset enddecrypt;

begindecryt : // 标记代码的起始地址

MessageBox(NULL, _T(“Hello World”), _T(“OK”), MB_ICONEXCLAMATION);

enddecrypt: // 标记代码的结束地址

size = address2 – address1;

if(CRC32(BYTE*)address1, size) == 0x78E888AE)

return  TRUE;

else

return  FALSE;

 

使 .text 区块可写

在Win32 平台上,文件编译后,.text 区块的属性石只读的,但是要是写,必须通过PE工具修改.text区块的属性为E0000020h 表示可写 可读 可执行

void Docrypt(DWORD* pData, DWORD Size, DWRD value)

{

         // 首先要做的是改变着一块虚拟内存的内存保护状态,以便可以自由存取代码

         MEMORY_BASIC_INFORMATION mbi_thunk;

         // 查询页信息

         VirtualQuery(pData, &mbi_thunk, sizeof(MEMORY_BASIC_INFORMATION));

         // 改写页保护属性为读写

         VirtualProtect(mbi_thunk.BaseAddress, mbi_thunk.RegionSize, PAGE_READWRITE, &mbi_thunk.Protect);

size = Size/0x4;  // 对数据共需要异或的次数

While(Size –)

{

                   *pData = (*pData) ^ value;

                   pData ++;

}

// 恢复也的元保护属性

DWORD dwOldProtect

VirtualProtect(mbi_thunk.BaseAddress,

mbi_thunk.RegionSize,

mbi_thunk.Protect,

&dwOldProtect);

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167207.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 中国十大技术社区你都知道哪些?

    中国十大技术社区你都知道哪些?社区是聚集一类具有相同爱好或者相同行业的群体,IT技术社区就是聚集了IT行业内的技术人,在技术社区可以了解到行业的最新进展,学习最前沿的技术,认识有相同爱好的朋友,在一起…

    2022年5月21日
    201
  • 关闭Apache的目录浏览功能[通俗易懂]

    关闭Apache的目录浏览功能[通俗易懂]用apache搭建的网站,默认情况下,是可以支持目录浏览的,也就是说,在目录中没有首页文件如index.html,index.php时,如果直接访问一个目录,这时就会显示整个目录包含的文件,这可能带来安全问题。关闭方法:修改配置文件httpd.conf把OptionsIndexesFollowSymLinks注释掉示例:<Directory”/var/www/html”> OptionsIndexesFollowSymLinks</Directory&

    2022年7月12日
    21
  • 【灯哥开源四足机器人】推荐一个开源四足机器狗项目,8自有度,两个舵机控制一个腿,apache开源协议的,已经迭代了好多个版本了,设计的非常好。有官方淘宝店,没有3D打印机的可以购买散装零件自己组装[通俗易懂]

    【灯哥开源四足机器人】推荐一个开源四足机器狗项目,8自有度,两个舵机控制一个腿,apache开源协议的,已经迭代了好多个版本了,设计的非常好。有官方淘宝店,没有3D打印机的可以购买散装零件自己组装[通俗易懂]目录前言1,关于【灯哥开源四足机器人】2,使用py-apple3,总结前言本文的原文连接是:https://blog.csdn.net/freewebsys/article/details/108971807未经博主允许不得转载。博主地址是:http://blog.csdn.net/freewebsys1,关于【灯哥开源四足机器人】灯哥开源的四足机器人(不是我)。作者的主页:https://www.bilibili.com/video/BV1Ka4y1t7CLgithub首页:h

    2022年6月9日
    70
  • vscode配置java环境变量_vscode java环境

    vscode配置java环境变量_vscode java环境VScode配置Java环境小白成功配置完Java环境后的自我记录VScode下载在vscode官网:https://code.visualstudio.com/选择相应版本下载安装JDK下载vscode仅支持JDK11及以上版本JDK11下载:https://www.oracle.com/java/technologies/javase-jdk11-downloads.html可选择其他更高版本配置环境变量找到JDK安装的文件路径,复制文件路径在桌面上找到此电脑右键属性点

    2022年9月27日
    1
  • 金九银十准备季:Java IO流面试题(含答案)「建议收藏」

    金九银十准备季:Java IO流面试题(含答案)「建议收藏」前言本题集列举了众多IT公司面试真题,对应聘Java程序员职位的常见考点和知识体系都进行的分类和归纳整理。本题集适合应聘Java和JavaEE职位的程序员作为面试复习、学习和强化的资料,也适合其他程序员作为拓展读物进行阅读。本题集包含了常见的算法、面试题,也包含了新的高级技术,比如:微服务架构等技术的面试题目。本题集非常全面,对于工作1-5年左右的java程序员面试有非常好的指导作用。大家也可以访问(直接在线观看最新版的面试题):Java考试_Java笔试题机试题真题讲解_JavaWeb

    2022年5月28日
    32
  • string类型保留两位小数_js保留4位小数

    string类型保留两位小数_js保留4位小数一Math.round(),Math.ceil(),Math.floor()的区别Math.round():根据“round”的字面意思“附近、周围”,可以猜测该函数是求一个附近的整数小数点后第一位<5正数:Math.round(11.46)=11负数:Math.round(-11.46)=-11小数点后第一位>5正数:Math.round(11.68)=12负数:Math.rou…

    2022年8月10日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号