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

wordpress url斜杠广州网站优化软件

wordpress url斜杠,广州网站优化软件,微网站如何建立,天津餐饮网站建设一、什么是进程注入? 进程注入是将代码或者dll插入另一个目标进程的地址空间中,并强制该进程执行注入的代码。与dll注入不同,直接代码注入相对隐蔽,不需要额外的DLL文件。该技术通常会有如下应用场景: 游戏外挂开发安…

一、什么是进程注入?

进程注入是将代码或者dll插入另一个目标进程的地址空间中,并强制该进程执行注入的代码。与dll注入不同,直接代码注入相对隐蔽,不需要额外的DLL文件。该技术通常会有如下应用场景:

  • 游戏外挂开发
  • 安全软件检测
  • 进程监控
  • 恶意软件分析

二、实现注入程序

注入程序实现思路如下:

  1. 通过窗口标题找到扫雷程序
  2. 获取目标进程ID
  3. 打开目标进程获取句柄
  4. 在目标进程中分配可执行内存
  5. 获取MessageBoxA函数地址
  6. 创建远程线程执行注入代码

实现代码如下;

.586
.model flat,stdcall
option casemap:noneinclude windows.inc
include user32.inc
include kernel32.incincludelib user32.lib
includelib kernel32.libInjectCode proto .datagameWindowCaption     db "扫雷",0injectionSuccessTitle db "注入成功",0 injectionMessage      db "扫雷进程被注入!",0  
.codeInjectedCodeStart:
invoke MessageBox, NULL, offset injectionMessage, offset injectionSuccessTitle, MB_OK; ---------------------------------------------------------------------------
InjectCode proc LOCAL @hwndMinesweeper   :HWNDLOCAL @dwTargetProcessId :DWORDLOCAL @hTargetProcess    :HANDLELOCAL @lpRemoteCode      :LPVOIDLOCAL @dwBytesWritten    :DWORDinvoke FindWindow, NULL, offset gameWindowCaptionmov    @hwndMinesweeper, eaxinvoke GetWindowThreadProcessId, @hwndMinesweeper, addr @dwTargetProcessIdinvoke OpenProcess, PROCESS_ALL_ACCESS, FALSE, @dwTargetProcessIdmov   @hTargetProcess, eaxinvoke VirtualAllocEx, @hTargetProcess, NULL, 1, MEM_COMMIT, PAGE_EXECUTE_READWRITE mov   @lpRemoteCode, eaxinvoke WriteProcessMemory, @hTargetProcess, @lpRemoteCode, offset InjectedCodeStart, offset InjectCode - offset InjectedCodeStart,addr @dwBytesWritteninvoke CreateRemoteThread, @hTargetProcess, NULL, 0, @lpRemoteCode, NULL, 0, NULLmov eax, 0 ret
InjectCode endpstart:invoke InjectCodeinvoke ExitProcess, eaxend start

经过编译执行上述代码后,我们发现扫雷进程会自动退出。通过使用OD进行调试,可以确认WriteProcessMemory操作执行成功。因此,现在使用OD附加到扫雷进程,并对扫雷进程中写入地址出设设置断点(也可以直接在注入的代码中增加int 3指令),写入到进程中的代码如下:
在这里插入图片描述
这里明显有问题,地址0x403005和0x40300E是注入进程中的地址。在数据窗口中搜索,发现不存在:
在这里插入图片描述
这引出一个核心问题:如何正确处理注入到目标进程的代码重定位。解决方案是通过计算注入进程与目标进程的地址差值,然后为注入代码中的字符串地址和函数地址加上这个差值即可实现重定位。与此同时,我们的注入程序中的funcMessageBox是在代码段,当前只有可读和执行权限,因此需要修改内存属性。重定位原理示意图如下所示:
在这里插入图片描述
修正后的代码如下:

.586
.model flat,stdcall
option casemap:noneinclude windows.inc
include user32.inc
include kernel32.incincludelib user32.lib
includelib kernel32.libInjectCode proto .datagameWindowCaption     	db "扫雷",0szUser32 				db "user32.dll", 0   szMessageBox 			db "MessageBoxA", 0.codeInjectedCodeStart:jmp MsgBoxinjectionSuccessTitle 	db "Injection successful",0 injectionMessage      	db "The winmine process was injected!",0 funcMessageBox   	dd 0
MsgBox:pushadcall Next
Next:pop 	ebxsub 	ebx ,offset Nextpush 	MB_OKmov 	eax, offset injectionSuccessTitleadd 	eax, ebxpush 	eaxmov 	eax, offset injectionMessageadd 	eax, ebxpush 	eaxpush 	NULLmov 	eax, offset funcMessageBox   add 	eax, ebx   call 	dword ptr [eax]popadret
InjectedCodeStart_End:dwCodeSize dd offset InjectedCodeStart_End - offset InjectedCodeStart; ---------------------------------------------------------------------------
InjectCode proc LOCAL @hwndMinesweeper   :HWNDLOCAL @dwTargetProcessId :DWORDLOCAL @hTargetProcess    :HANDLELOCAL @lpRemoteCode      :LPVOIDLOCAL @dwBytesWritten    :DWORDLOCAL @dwOldProc:DWORDLOCAL @hUser32:DWORDinvoke LoadLibrary, offset szUser32mov @hUser32, eax;修改内存属性invoke VirtualProtect, offset funcMessageBox, size funcMessageBox, PAGE_EXECUTE_READWRITE, addr @dwOldProcinvoke GetProcAddress, @hUser32, offset szMessageBoxmov funcMessageBox, eax;还原内存属性invoke VirtualProtect, offset funcMessageBox, size funcMessageBox, @dwOldProc, addr @dwOldProcinvoke FindWindow, NULL, offset gameWindowCaptionmov    @hwndMinesweeper, eaxinvoke GetWindowThreadProcessId, @hwndMinesweeper, addr @dwTargetProcessIdinvoke OpenProcess, PROCESS_ALL_ACCESS, FALSE, @dwTargetProcessIdmov   @hTargetProcess, eaxinvoke VirtualAllocEx, @hTargetProcess, NULL, 1, MEM_COMMIT, PAGE_EXECUTE_READWRITE mov   @lpRemoteCode, eaxinvoke WriteProcessMemory, @hTargetProcess, @lpRemoteCode, offset InjectedCodeStart, dwCodeSize,addr @dwBytesWritteninvoke CreateRemoteThread, @hTargetProcess, NULL, 0, @lpRemoteCode, NULL, 0, NULLmov eax, 0 ret
InjectCode endpstart:invoke InjectCodeinvoke ExitProcess, eaxend start

执行结果如下所示:
在这里插入图片描述

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

相关文章:

  • 做弹幕视频效果的网站免费下载百度到桌面
  • 湛江网站建设推广百度一下就知道百度首页
  • 承德网站制作公司哪家好网络营销推广的特点
  • 中小企业网站建设方案2021十大网络舆情案例
  • 北京网站设计公司飞沐交换链接的作用
  • 织梦后台搭建网站并调用标签建设吉林seo管理平台
  • 门户网站建设重建方案成都自然排名优化
  • 郑州哪有做网站的google国际版
  • 网站建设规划书范文5000字湖南网络推广服务
  • 采用wordpressseo优化技术是什么
  • 自动化设计网站建设网址大全qq浏览器
  • php网站开发工具河北seo关键词排名优化
  • 音乐培训如何做网站宣传营销策划公司介绍
  • 网站制作内容app推广实名认证接单平台
  • 网站建设与网页设计专业专业培训机构
  • 自建网站怎么做后台管理系统专业网络推广公司排名
  • 网站的下拉列表怎么做百度快速排名培训
  • 贵阳个人做网站网站seo站长工具
  • 仪征建设银行官方网站互联网广告代理可靠吗
  • 上海 培训网站建设太原百度快照优化排名
  • 站酷设计网站官各引擎收录查询
  • 长页网站镇江百度推广
  • 网页设计制作思路信息流优化师没经验可以做吗
  • 阜新公司做网站在线搜索引擎
  • 自己做的视频网站视频加载慢steam交易链接在哪
  • 网站建设 知识产权宣传推广方式有哪些
  • 婚纱摄影网站管理系统软文广告案例分析
  • 网络游戏排行榜2022前十名上海aso苹果关键词优化
  • 网站代码语法seo搜狗
  • 网站怎么做好优化1000个关键词