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

哈尔滨服务好的建站方案wordpress中文版开发文档

哈尔滨服务好的建站方案,wordpress中文版开发文档,北海seo快速排名,三种人不适合编程目录 简介 编写SMC程序 测试patch后的程序 参考 简介 自修改代码(Self-Modified Code)是一类特殊的代码加密技术,即在运行时修改自身代码或数据,从而使得程序实际行为与反汇编结果不符,同时修改前的代码段数据也可…

目录

简介

编写SMC程序

测试patch后的程序

参考


简介

自修改代码(Self-Modified Code)是一类特殊的代码加密技术,即在运行时修改自身代码或数据,从而使得程序实际行为与反汇编结果不符,同时修改前的代码段数据也可能非合法指令,从而无法被反汇编器识别,这加大了软件逆向工程的难度

基本原理是在编译可执行文件时,将需要加密的代码区段(如函数、代码块) 单独编译成一个section(段),并将其标记为可读,可写,不可执行,然后通过某种方法在程序运行的时候将section解密为可执行代码,并将其标记为可读、可执行、不可写,这样就不能直接在内存里面找到加密的代码,从而无法执行或修改加密的代码

SMC的实现方式有很多种,可以通过修改PE文件的Section Header、使用API Hook实现代码加密和解密、使用VMProtect等第三方加密工具等

SMC两种破解方式,第一种是根据静态分析结果直接修改程序二进制文件,第二种则是在动态调试时将解密后的程序从内存中 dump 下来

编写SMC程序

一般smc程序的执行流程(假设关键函数为func)

  1. main函数中获取func函数的地址

  2. 取消func函数处的页面保护

  3. 对func进行解密操作之后再调用func

为了编写smc程序,我们需要进行如下操作

  1. 先写好func函数和main函数中的解密代码(此时不能真正解密,还需要矫正)

  2. 编译后用ida打开exe程序,找到func地址及大小,从而修正主函数的参数

  3. 用ida对func函数进行patch,保存patch后的程序

#include<stdio.h>
#include<Windows.h>
int func(int x, int y) {unsigned int z = 0x12345678;x = y ^ z;y = x ^ z;char flag[] = "helloworld";printf("%s", flag);return x ^ y ^ z;
}
int main() {DWORD64 old;byte* pfunc = (byte*)func;//函数地址VirtualProtect(func,0xE1, PAGE_EXECUTE_READWRITE, &old);//第二个参数为大小,可以编译后通过ida查看得到pfunc = pfunc + *(DWORD*)(pfunc+1) + 5;//加上偏移值才是真实func地址+5是由于e9 jmp指令后的四字节是相对偏移for (int i = 0; i < 0xE1; i++)//解密操作 也需要修正大小 这里是修正后的pfunc[i] ^= 0x12;
​func(5, 6);return 0;
}

如果直接运行该程序肯定会出错,因为此时相当于对func函数加密而非解密,所以需要用ida进行patch,idapython脚本进行patch

import idc
import ida_bytes
addr=0x140011890
for i in range(0xe1):tmp=idc.get_wide_byte(addr)ida_bytes.patch_byte(addr,tmp^0x12)addr=addr+1

记得保存patch后的程序,再用ida打开patch后的程序,在解密func函数可用脚本解密或下断点动调观察

测试patch后的程序

解密前的func函数,无法正常识别

解密后的func,ida重新识别可反编译

参考

smc动态加密技术

风信子培训smc

http://www.dtcms.com/wzjs/543920.html

相关文章:

  • 网页和网站做哪个好用西安三大品牌设计公司
  • 做saas平台网站临沂网站建设搭建
  • 有没有网站可以做地图昆山汽车网站建设
  • 重庆企业站seo会计公司网站模板
  • 站酷的网址安阳做网站的公司有哪些
  • 南昌p2p网站建设广州网页设计培训班
  • 如何做自己的淘客网站广告图案大全图片素材
  • 开个人网站怎么赚钱深圳特区建设
  • 建站平台是给谁用的商业中心 网站建设
  • 做网站学好哪些软件六安建筑模板厂家10强
  • 网站服务器基本要素网站推广 济南
  • 网站服务器和空间大小中信建设有限责任公司客户
  • 求个网站2021创客贴做网站吗
  • flash网站模板网站买云服务哪家好
  • 柳州城乡建设部网站首页传奇网站一般怎么做的
  • 衡阳市建设学校官方网站阿里云怎么申请域名
  • 网站开发和合同范本西安外贸建站
  • 长沙银狐做网站网站关键词多少个
  • 网站视频大全网站备案照
  • 主机销售网站源码wordpress微博评论箱
  • 济宁网站建设找哪家免费企业邮箱推荐
  • 网站建设模拟实训题潍坊网站建设公司推荐
  • 哪个网站做logo好佛山外贸网站制作公司
  • 泉州北京网站建设价格wordpress开启ssl强制跳转
  • 重庆网站建站推广网站后台开发教程
  • 58同城通辽做网站企业电话
  • 网站搭建需要什么技术学做电商的网站有哪些
  • 响应式网站404页面怎么做网页交互设计
  • 会员系统网站制作网络营销公司名字大全
  • 网站建设理论依据做app公司