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

巴音郭楞网络营销沈阳百度seo关键词优化排名

巴音郭楞网络营销,沈阳百度seo关键词优化排名,公司做网站怎么赚钱吗,久雅科技软件开发外包我们继续延申调试事件的话题,实现进程转存功能,进程转储功能是指通过调试API使获得了目标进程控制权的进程,将目标进程的内存中的数据完整地转存到本地磁盘上,对于加壳软件,通常会通过加密、压缩等手段来保护其代码和数…

我们继续延申调试事件的话题,实现进程转存功能,进程转储功能是指通过调试API使获得了目标进程控制权的进程,将目标进程的内存中的数据完整地转存到本地磁盘上,对于加壳软件,通常会通过加密、压缩等手段来保护其代码和数据,使其不易被分析。在这种情况下,通过进程转储功能,可以将加壳程序的内存镜像完整地保存到本地,以便进行后续的分析。

在实现进程转储功能时,主要使用调试API和内存读写函数。具体实现方法包括:以调试方式启动目标进程,将其暂停在运行前的位置;让目标进程进入运行状态;使用ReadProcessMemory函数读取目标进程内存,并将结果保存到缓冲区;将缓冲区中的数据写入文件;关闭目标进程的调试状态。

首先老样子先来看OnException回调事件,当进程被断下时首先通过线程函数恢复该线程的状态,在进程被正确解码并运行起来时直接将该进程的EIP入口地址传递给MemDump();内存转存函数,实现转存功能;

void OnException(DEBUG_EVENT *pDebug, BYTE *bCode)
{CONTEXT context;DWORD dwNum;BYTE bTmp;// 打开当前进程与线程HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, pDebug->dwProcessId);printf("[+] 当前打开进程句柄: %d 进程PID: %d \n", hProcess, pDebug->dwProcessId);HANDLE hThread = OpenThread(THREAD_ALL_ACCESS, FALSE, pDebug->dwThreadId);printf("[+] 当前打开线程句柄: %d 线程PPID: %d \n", hThread, pDebug->dwThreadId);// 暂停当前线程SuspendThread(hThread);// 读取出异常产生的首地址ReadProcessMemory(hProcess, pDebug->u.Exception.ExceptionRecord.ExceptionAddress, &bTmp, sizeof(BYTE), &dwNum);printf("[+] 当前异常产生地址为: 0x%08X \n", pDebug->u.Exception.ExceptionRecord.ExceptionAddress);// 设置当前线程上下文,获取线程上下文context.ContextFlags = CONTEXT_FULL;GetThreadContext(hThread, &context);printf("[-] 恢复断点前: EAX = 0x%08X  EIP = 0x%08X \n", context.Eax, context.Eip);// 将刚才的CC断点取消,也就是回写原始的指令集WriteProcessMemory(hProcess, pDebug->u.Exception.ExceptionRecord.ExceptionAddress, bCode, sizeof(BYTE), &dwNum);// 当前EIP减一并设置线程上下文context.Eip--;SetThreadContext(hThread, &context);printf("[+] 恢复断点后: EAX = 0x%08X  EIP = 0x%08X \n", context.Eax, context.Eip);printf("[+] 获取到动态入口点: 0x%08x \n", pDebug->u.CreateProcessInfo.lpBaseOfImage);// 转储内存镜像MemDump(pDebug, context.Eip, (char *)"dump.exe");// 恢复线程ResumeThread(hThread);CloseHandle(hThread);CloseHandle(hProcess);
}

MemDump函数中,首先通过调用CreateFile函数打开me32.szExePath路径也就是转存之前的文件,通过使用VirtualAlloc分配内存空间,分配大小是PE头中文件实际大小,接着OpenProcess打开正在运行的进程,并使用ReadProcessMemory读取文件的数据,此处读取的实在内存中的镜像数据,当读取后手动修正,文件的入口地址,及文件的对齐方式,接着定位PE节区数据,找到节区首地址,并循环将当前节区数据赋值到新文件缓存中,最后当一切准备就绪,通过使用WriteFile函数将转存后的文件写出到磁盘中;

void MemDump(DEBUG_EVENT *pDe, DWORD dwEntryPoint, char *DumpFileName)
{// 得到当前需要操作的进程PIDDWORD dwPid = pDe->dwProcessId;MODULEENTRY32 me32;// 对系统进程拍摄快照HANDLE hSnap = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE, dwPid);me32.dwSize = sizeof(MODULEENTRY32);// 得到第一个模块句柄,第一个模块句柄也就是程序的本体BOOL bRet = Module32First(hSnap, &me32);printf("[+] 当前转储原程序路径: %s \n", me32.szExePath);// 打开源文件,也就是dump之前的文件HANDLE hFile = CreateFile(me32.szExePath, GENERIC_READ, FILE_SHARE_READ, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);if (hFile == INVALID_HANDLE_VALUE)exit(0);// 判断PE文件的有效性IMAGE_DOS_HEADER imgDos = { 0 };IMAGE_NT_HEADERS imgNt = { 0 };DWORD dwReadNum = 0;// 读入当前内存程序的DOS头结构ReadFile(hFile, &imgDos, sizeof(IMAGE_DOS_HEADER), &dwReadNum, NULL);// 判断是否是一个合格的DOS头if (imgDos.e_magic != IMAGE_DOS_SIGNATURE)return;// 设置文件指针到NT头上SetFilePointer(hFile, imgDos.e_lfanew, 0, FILE_BEGIN);ReadFile(hFile, &imgNt, sizeof(IMAGE_NT_HEADERS), &dwReadNum, NULL);// 判断是否是合格的NT头if (imgNt.Signature != IMAGE_NT_SIGNATURE)return;// 得到EXE文件的大小DWORD BaseSize = me32.modBaseSize;printf("[+] 当前内存文件大小: %d --> NT结构原始大小: %d 一致性检测: True \n", BaseSize, imgNt.OptionalHeader.SizeOfImage);// 如果PE头中的大小大于实际内存大小,则以PE头中大小为模板if (imgNt.OptionalHeader.SizeOfImage > BaseSize){BaseSize = imgNt.OptionalHeader.SizeOfImage;}// 分配内存空间,分配大小是PE头中文件实际大小,并打开进程LPVOID pBase = VirtualAlloc(NULL, BaseSize, MEM_COMMIT, PAGE_READWRITE);printf("[+] 正在分配转储空间 句柄: %d \n", pBase);HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, dwPid);// 读取文件的数据,此处读取的实在内存中的镜像数据bRet = ReadProcessMemory(hProcess, me32.modBaseAddr, pBase, me32.modBaseSize, NULL);// 判断PDOS头的有效性PIMAGE_DOS_HEADER pDos = (PIMAGE_DOS_HEADER)pBase;if (pDos->e_magic != IMAGE_DOS_SIGNATURE)return;// 计算出NT头数据PIMAGE_NT_HEADERS pNt = (PIMAGE_NT_HEADERS)(pDos->e_lfanew + (PBYTE)pBase);if (pNt->Signature != IMAGE_NT_SIGNATURE)return;// 设置文件的入口地址pNt->OptionalHeader.AddressOfEntryPoint = dwEntryPoint - pNt->OptionalHeader.ImageBase;printf("[*] 正在设置Dump文件相对RVA入口地址: 0x%08X \n", pNt->OptionalHeader.AddressOfEntryPoint);// 设置文件的对齐方式pNt->OptionalHeader.FileAlignment = 0x1000;printf("[*] 正在设置Dump文件的对齐值: %d \n", pNt->OptionalHeader.FileAlignment);// 找到节区首地址,并循环将当前节区数据赋值到新文件缓存中PIMAGE_SECTION_HEADER pSec = (PIMAGE_SECTION_HEADER)((PBYTE)&pNt->OptionalHeader + pNt->FileHeader.SizeOfOptionalHeader);for (int i = 0; i < pNt->FileHeader.NumberOfSections; i++){pSec->PointerToRawData = pSec->VirtualAddress;printf("[+] 正在将虚拟地址: 0x%08X --> 设置到文件地址: 0x%08X \n", pSec->VirtualAddress, pSec->PointerToRawData);pSec->SizeOfRawData = pSec->Misc.VirtualSize;printf("[+] 正在将虚拟大小: %d --> 设置到文件大小: %d \n", pSec->Misc.VirtualSize, pSec->SizeOfRawData);pSec++;}CloseHandle(hFile);// 打开转储后的文件.hFile = CreateFile(DumpFileName, GENERIC_WRITE, FILE_SHARE_READ, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);if (hFile == INVALID_HANDLE_VALUE)exit(0);printf("[*] 转储 %s 文件到本地 \n", DumpFileName);DWORD dwWriteNum = 0;// 将读取的数据写入到文件bRet = WriteFile(hFile, pBase, me32.modBaseSize, &dwWriteNum, NULL);if (dwWriteNum != me32.modBaseSize || FALSE == bRet)printf("写入错误 !");// 关闭于释放资源CloseHandle(hFile);VirtualFree(pBase, me32.modBaseSize, MEM_RELEASE);CloseHandle(hProcess);CloseHandle(hSnap);
}

读者可自行运行这段程序,当程序运行后即可将指定的一个文件内存数据完整的转存到磁盘中,输出效果如下图所示;

本文作者: 王瑞
本文链接: https://www.lyshark.com/post/5e2f7b11.html
版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!

http://www.shuangfujiaoyu.com/news/59599.html

相关文章:

  • 重庆网上制作网站百度网站提交了多久收录
  • qq官方网站登录入口合肥网站推广助理
  • 做牛仔裤的视频网站微信裂变营销软件
  • 网络商城网站怎样做关键词优化百度文库账号登录入口
  • 嘉定做网站的个人博客网页设计
  • 网络域名解析错误郑州本地seo顾问
  • 绵阳网站建设怎么做北京seo诊断
  • 长春网站优化咨询社交媒体营销
  • 电商网站取名外贸定制网站建设电话
  • 做系统软件的网站网站优化排名方法有哪些
  • 手机怎么创建链接网址seo技术顾问阿亮
  • 打开网站后直接做跳转友情链接的作用大不大
  • 长春网站设计制作福州网站快速排名提升
  • 代驾软件开发流程seo课程哪个好
  • 网站做弹窗广告怎么查询百度收录情况
  • 怎么做快三一模一样的网站网站首页不收录
  • go 是做网站的吗新闻发布会
  • 哈尔滨做网站电话品牌策略有哪些
  • 厦门建筑网长沙网站优化推广方案
  • 群辉可以做网站服务器吗百度识图软件
  • 平台门户网站建设搜索引擎seo关键词优化
  • wordpress seo tdk汕头seo推广优化
  • 做一网站要学些什么短视频培训要多少学费
  • 做百度手机网站点击手机百度搜索
  • 做威士忌的网站百度快照推广
  • 新疆网站建设大全线上营销方式主要有哪些
  • ip地址直接访问网站深圳知名网络优化公司
  • 系部网站建设中期检查表成都百度推广代理公司
  • 两学一做党员夜校播放网站引流用什么话术更吸引人
  • 手机网站制作时应该注意的问题seo顾问合同