【搬砖】【突破极限?】32位进程成功申请超过4GB内存!!  

前言:

  • 本方法只能在x64系统上使用,32位的操作系统的易友就不用继续往下看了。

程序使用到的模块:

正文:

  • 众所周知:在64位系统上,32位程序依赖Wow64子系统运行。
  • 这个Wow64子系统本质上是由4个64位的Dll(ntdll.dll,wow64.dll,wow64win.dll,wow64cpu.dll)模拟了一个32位的程序。(这个进程虽然是运行的32位代码,但API接口核心由64位完成,甚至这个进程有64位的PEB、TEB和32位的PEB、TEB,系统判断进程是否为32位无非是检查TEB->WowTebOffset的值)
  • 所以本质上64位系统下的32位程序是有64位进程的特性。
  • 所以只要突破系统对于进程的限制,申请大内存的问题就迎刃而解了。
  • 如何突破?直接用64位的NtAllocateVirtualMemory就可以了。
  • 测试效果:
  • 申请4GB内存测试(从Windows-Kernel-Explorer-master可以看到成功在0x0000000200000000处申请到内存):
  • 理论上使用这个方法后,64位系统下的32位进程就可以申请到高于32位的地址,实现真正意义上的32位可用内容的突破。
  • 注意:申请到的内存地址必须使用x64的命令进行访问
(已有13次下载)

本站所有资源不带技术支持,下载资源请24小时内删除,如用于违法用途,或者商业用途,一律使用者承担,本站不承担任何责任!

©️万宁卓尚科技工作室版权所有
源码BBS网 » 【搬砖】【突破极限?】32位进程成功申请超过4GB内存!!  

发表评论

发表评论

提供最优质的资源集合

立即查看 了解详情