CN115481397B - 基于内存结构逆向分析的代码注入攻击取证检测方法与系统 - Google Patents
基于内存结构逆向分析的代码注入攻击取证检测方法与系统 Download PDFInfo
- Publication number
- CN115481397B CN115481397B CN202211062373.2A CN202211062373A CN115481397B CN 115481397 B CN115481397 B CN 115481397B CN 202211062373 A CN202211062373 A CN 202211062373A CN 115481397 B CN115481397 B CN 115481397B
- Authority
- CN
- China
- Prior art keywords
- page
- memory
- virtual memory
- page set
- virtual
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/55—Detecting local intrusion or implementing counter-measures
- G06F21/56—Computer malware detection or handling, e.g. anti-virus arrangements
- G06F21/566—Dynamic detection, i.e. detection performed at run-time, e.g. emulation, suspicious activities
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2221/00—Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/03—Indexing scheme relating to G06F21/50, monitoring users, programs or devices to maintain the integrity of platforms
- G06F2221/033—Test or assess software
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Hardware Design (AREA)
- General Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Virology (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
本发明提供一种基于内存结构逆向分析的代码注入攻击取证检测方法与系统。该方法包括:步骤1:对内存映像文件进行预处理,得到物理内存页面集合P;步骤2:基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;步骤3:逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;步骤4:根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;步骤5:逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;步骤6:比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
Description
技术领域
本发明涉及电子(数字)犯罪取证技术领域,尤其涉及一种基于内存结构逆向分析的代码注入攻击取证检测方法与系统,特别适合于正在运行的基于Windows不同版本操作系统的物理内存中新型代码注入攻击行为的检测与取证分析。
背景技术
随着网络安全领域的攻防博弈,DLL注入发展出了一系列新的变种技术,与经典的DLL注入方法不同,新型DLL注入攻击避免受害进程调用系统API加载恶意DLL,使受害进程的加载模块链表(LDR)中没有注入DLL的信息,而且可能篡改虚拟地址描述符(VirtualAddress Descriptor,VAD)的属性,实现了隐蔽注入恶意DLL模块。新型DLL注入的主要攻击目标是用户空间进程,注入的手段更加复杂与隐蔽。如Stephen等提出的反射式注入技术(Reflective code inject)、Mieleke等人提出的Process Hollowing技术,以及Palutke等提出的VAD重映射技术。而且,一些恶意软件使用了类似的攻击技术,如Duqu2.0(2015)、Dyre银行木马(2015)、Conti勒索软件(2020)等,造成了广泛严重的危害,因此对新型DLL注入攻击的检测十分重要。
目前基于内存取证的注入页面检测方法主要关注虚拟内存空间,尤其依赖于VAD的属性,在应对新型注入攻击时检测准确率低。如Volatility和Rekall的malfind插件检测VAD的标签、私有状态和保护属性,但是该方法检测条件过于粗略,容易产生误检,并且无法检测如VAD重映射等修改了VAD保护属性的恶意代码;Pshoul提出基于调用栈检测线程注入的方法,并开发了malthfind插件,Srivastava等提出了类似的基于调用栈分析的注入检测方法,能检测修改了VAD保护属性的注入技术,但是基于堆栈调用无法检测还未执行的隐蔽注入页面。Cohen提出了在逻辑不连续的物理内存中匹配YARA签名的方法,但是需要输入目标恶意软件的签名,无法检测未知的恶意软件;Block等提出把PTE的可执行属性作为可执行物理内存页面的特征,但是该方法会报告所有修改过的内存映射,包含了大量的良性内存页面,难以准确定位恶意内存页面。
发明内容
针对现有方法对新型注入攻击的检测准确率较低的问题,本发明提供一种基于基于内存结构逆向分析的代码注入攻击取证检测方法与系统。
第一方面,本发明提供一种基于内存结构逆向分析的代码注入攻击取证检测方法,包括:
步骤1:对内存映像文件进行预处理,得到物理内存页面集合P;
步骤2:基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;
步骤3:逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;
步骤4:根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;
步骤5:逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;
步骤6:比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
进一步地,步骤1具体包括:
对内存映像文件进行解析后得到原始物理内存数据,按照4KB大小对所述原始物理内存数据进行分页管理,得到由若干个4KB内存页面组成的物理内存页面集合P。
进一步地,步骤2具体包括:
初始化DLL代码模块物理内存页面集合Pe,然后遍历物理内存页面集合P,将集合P中含有DLL头部特征的内存页面全部加入至集合Pe中,直至遍历完集合P中的所有内存页面,得到最终的集合Pe。
进一步地,步骤3具体包括:
步骤3.1:在EPROCESS中搜索已知进程的名称,根据搜索结果构建EPROCESS结构;
步骤3.2:采用_KUSER_SHARED_DATA结构验证所构建的EPROCESS结构是否正确;若正确,执行步骤3.3;
步骤3.3:从EPROCESS结构中读取进程的页表物理地址DTB值,进而由内存页表构建得到该进程的虚拟页面到物理页面的映射关系;
步骤3.4:根据EPROCESS结构中的ActiveProcessLinks获取与其相邻的两个EPROCESS结构的虚拟地址;
步骤3.5:根据已获取的进程的虚拟页面到物理页面的映射关系和相邻的两个EPROCESS结构的虚拟地址,构建得到相邻两个新的进程EPROCESS结构;
步骤3.6:针对每个新的进程EPROCESS结构,返回执行步骤3.3至步骤3.5,直至遍历完成所有进程的EPROCESS结构,即可得到虚拟内存空间到物理内存空间的页面映射t。
进一步地,步骤4具体包括:
针对每个进程,根据进程的用户空间地址范围得到每个进程的用户空间页面集合;计算所有进程的用户空间页面集合的并集得到用户空间页面集合Vu;
遍历所有虚拟内存页面,针对每个虚拟内存面执行页面映射t转换页面,若转换后的页面属于DLL代码模块物理内存页面集合Pe,则将该虚拟内存页面加入至虚拟内存页面集合Ve;遍历完成所有虚拟内存页面后即可得到最终的虚拟内存页面集合Ve。
进一步地,步骤5具体包括:
针对每个进程,从其EPROCESS结构中读取PEB的指针,然后找到LDR链表,读取链表项得到每个进程的LDR链表中DLL代码模块虚拟内存页面集合Vproc_l;
计算所有进程的LDR链表中DLL代码模块虚拟内存页面集合Vproc_l的并集,即为DLL代码模块虚拟内存页面集合Vl。
第二方面,本发明提供一种基于内存结构逆向分析的代码注入攻击取证检测系统,包括:
预处理模块,用于对内存映像文件进行预处理,得到物理内存页面集合P;
物理定位模块,用于基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;
虚拟空间逆向构建模块,用于逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;以及用于逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;
隐蔽页面识别模块,用于根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;以及用于比较虚拟内存页面集合Ve、代码模块虚拟内存页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
第三方面,本发明提供一种电子设备,包括:存储器和处理器,所述处理器和所述存储器通过总线完成相互间的通信;所述存储器存储有可被所述处理器执行的程序指令,所述处理器调用所述程序指令能够执行上述的方法,例如包括:对内存映像文件进行预处理,得到物理内存页面集合P;基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
第四方面,本发明提供一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现上述的方法,例如包括:对内存映像文件进行预处理,得到物理内存页面集合P;基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
本发明的有益效果:
本发明提供的基于内存结构逆向分析的代码注入攻击取证检测方法与系统,首先从物理角度在内存映像中基于DLL特征定位其对应的物理内存页面,设计了一种物理内存空间与虚拟内存空间映射算法,建立了映射关系t,实现了DLL代码模块对应的物理页面子集逆向重建机制。然后从虚拟内存空间着手,逆向重建进程的LDR链表结构,并设计了一种DLL虚拟页面子集逆向重建算法,实现了其虚拟空间重建。最后设计并实现了基于物理内存页面子集和虚拟空间页面子集的DLL注入攻击隐蔽页面检测算法。本发明在检测过程中不使用VAD结构,因此不受VAD属性篡改攻击的影响。在实践中本发明由于更高的准确度,适合作为检测隐藏内存页的首选方法,以快速确定取证分析的调查方向。
附图说明
图1为本发明实施例提供的基于内存结构逆向分析的代码注入攻击取证检测方法的流程示意图;
图2为本发明实施例提供的在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe的示意图;
图3为现有的Windows系统进程管理结构,仅列出本发明涉及的变量;
图4为本发明实施例提供的在32位Win7系统中构建EPROCESS结构的示意图;
图5为本发明实施例提供的访问_KUSER_SHARED_DATA结构验证系统版本假设的示意图;
图6为本发明实施例提供的在32位Win7系统中通过ActiveProcessLinks访问相邻进程的示意图;
图7为本发明实施例提供的在32位Win7系统中找到LDR链表中的代码模块虚拟地址得示意图;
图8为本发明实施例提供的基于内存结构逆向分析的代码注入攻击取证检测系统的结构示意图;
图9为本发明实施例提供的一种电子设备的结构示意图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
新型DLL注入攻击指恶意软件避免受害进程调用系统API加载恶意DLL代码模块,使受害进程的加载模块链表(LDR)中没有注入DLL的信息。代码注入攻击取证检测的目标是从物理内存映像中检测新型注入攻击的隐蔽DLL代码模块。
为了描述问题和方法,本发明做出如下形式化描述:
记虚拟内存页面为vproc_addr,即一个虚拟内存页面v由进程和虚拟地址唯一确定;一个进程的虚拟空间记为Vproc,其中属于用户空间的子集记为Vpro_u,LDR链表中DLL代码模块虚拟内存页面集合记为Vproc_l;所有进程的虚拟内存页面构成集合V=∪procVproc,其中属于用户空间的子集记为Vu,LDR链表中DLL代码模块虚拟内存页面集合记为Vl;
记物理内存页面为paddr,即一个物理内存页面p由其物理地址唯一确定;所有物理内存页面构成集合P,DLL代码模块所在的物理内存页面子集记为Pe。虚拟内存空间到物理内存空间之间的转换关系记为映射t(v):V→P,虚拟内存中DLL代码模块所在的内存页面集合记为Ve,即集合Pe的原像集合。
实施例1
基于上述内容,本发明实施例提供了一种基于内存结构逆向分析的代码注入攻击取证检测方法,包括以下步骤:
S101:对内存映像文件进行预处理,得到物理内存页面集合P;
具体地,数据预处理的目的是从内存映像文件中读取原始物理内存数据。根据不同的内存映像格式需要不同的预处理,如微软的dmp格式崩溃转储文件在头部添加了元数据,剩下部分是原始的内存镜像;VMWare虚拟机捕获的内存快照包含两个文件,其中vmem文件就是原始内存数据,vmsn文件包含了元数据。由EnCase取证工具获取的内存映像为EWF格式,元数据和压缩过的原始内存数据在同一个文件中,需要使用专门的工具解析。
对内存映像文件进行解析后得到原始物理内存数据,操作系统一般按照4KB大小对内存分页管理,因此可以把原始物理内存数据作为4KB内存页面集合来处理,即构成物理内存页面集合P。
S102:基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;
具体地,DLL文件是按照PE文件的通用格式组织的,无论是正常加载DLL还是隐蔽注入的DLL,都要在虚拟内存中申请内存页面,按照PE文件的格式分块加载,并且这些虚拟内存页面必须映射到物理内存中,DLL模块才能够执行。
DLL头部代码模块小于4KB,在内存中会完整地加载到一个页面开头,特征字符串和相对偏移量都保持不变。虚拟内存映射到物理内存是整页映射的,因此PE头部在物理内存空间中也是不变的(如图2所示)。所以可以在物理内存页面集合P中直接搜索PE头部特征字符,定位所有包含DLL头部特征的物理内存页面。即:初始化DLL代码模块物理内存页面集合Pe,然后遍历物理内存页面集合P,将集合P中含有DLL头部特征的内存页面全部加入至集合Pe中,直至遍历完集合P中的所有内存页面,得到最终的集合Pe。
本发明实施例还给出了相应的算法代码,如算法1所示:
S103:逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;
具体地,用户空间进程及其加载模块管理结构LDR链表存在于虚拟内存空间中(如图3所示),而现代操作系统普遍使用地址空间配置随机加载机制(ASLR),使虚拟内存页面在物理内存中随机离散存储,只能通过页表把虚拟页面映射到物理页面以访问数据。所以逆向分析重建映像时,需要先找到进程EPROCESS结构,读取页表物理地址DTB的值,然后由内存页表构建虚拟页面到物理页面的映射关系t。其中,由页表构建页面映射的方法可以参考现有的研究工作,本发明不再赘述;本发明实施例重点设计了查找进程EPROCESS结构以及页表物理地址DTB的步骤。
基于上述内容,本步骤包括以下子步骤:
S1031:在EPROCESS中搜索已知进程的名称,根据搜索结果构建EPROCESS结构;
具体地,根据现有的研究工作,Windows内核每个版本中的结构基本不变,从WinXP到Win8.1版本中EPROCESS的结构布局只有10种,EPROCESS的结构是容易穷举的,因此可以搜索已知的进程名称来定位EPROCESS。
S1032:采用_KUSER_SHARED_DATA结构验证所构建的EPROCESS结构是否正确;若正确,执行步骤S1033;
具体地,对每个EPROCESS构建结果,通过_KUSER_SHARED_DATA结构验证系统版本的假设。_KUSER_SHARED_DATA的虚拟地址在各个版本中均为7ffe0000,且必定存在物理内存页面映射,其中NtMajorVersion和NtMinorVersion字段表示操作系统的主要版本和次要版本,两个值应该与假设的操作系统版本对应。
S1033:从EPROCESS结构中读取进程的页表物理地址DTB值,进而由内存页表构建得到该进程的虚拟页面到物理页面的映射关系;
S1034:根据EPROCESS结构中的ActiveProcessLinks获取与其相邻的两个EPROCESS结构的虚拟地址;
具体地,EPROCESS的ActiveProcessLinks是双向链表,两个虚拟地址指针分别指向相邻两个EPROCESS的ActiveProcessLinks地址。
S1035:根据已获取的进程的虚拟页面到物理页面的映射关系和相邻的两个EPROCESS结构的虚拟地址,构建得到相邻的两个新的进程EPROCESS结构;
S1036:针对每个新的进程EPROCESS结构,返回执行步骤S1033至步骤S1035,直至遍历完成所有进程的EPROCESS结构,即可得到虚拟内存空间到物理内存空间的页面映射t。
例如,以系统进程“smss.exe”为例,步骤如下:
(1)EPROCESS中ImageFileName字段为进程名,长度至少为15个字节,于是对进程名字符串“smss.exe”末尾使用’\0’填充到15个字节,即得到十六进制字符串“73 6D 73 732E 65 78 65 00 00 00 00 00 00 00”,在物理内存页面集合P中搜索该字符串。
(2)若已知操作系统版本,则EPROCESS结构唯一确定;若未知操作系统版本,对每个进程名搜索结果,构建所有可能的EPROCESS结构。如图4是假设操作系统是32位Win7时,对一个进程名搜索结果构建的EPROCESS结构。
(3)假设操作系统是32位Win7,对一个进程名搜索结果构建EPROCESS结构(如图4),读取DTB,根据32位系统的页表转换方法把_KUSER_SHARED_DATA的虚拟地址0x7ffe0000转换到物理地址0x1E2010(如图5),读取NtMajorVersion和NtMinorVersion字段的值分别为6和1,即系统内核版本为6.1,与32位Win7相符,可判定该EPROCESS构建是正确的。然后可构建smss进程空间中所有虚拟页面到物理页面的映射关系t(vsmss):Vsmss→Psmss。
(4)如图6所示,0x3F2D0568是smss进程的起始物理地址,读取ActiveProcessLinks链表中前后两个链表项的虚拟地址并分别减去相对起始位置的偏移量,得到相邻两个EPROCESS的虚拟地址。由映射t(vsmss):Vsmss→Psmss得到虚拟地址0x86049d40对应的物理地址为0x3f249d40,构建新的EPROCESS结构,从其ImageFileName字段知该进程为csrss,同时读取该进程的DTB为0x3f2d2060,据此可构建地址映射t(vcsrss):Vcsrss→Pcsrss。
(5)循环执行以上步骤直到遍历所有进程的EPROCESS,最终得到所有进程虚拟页面到物理页面的映射t(v):V→P。
S104:根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;
具体地,针对每个进程,根据进程的用户空间地址范围得到每个进程的用户空间页面集合;计算所有进程的用户空间页面集合的并集得到用户空间页面集合Vu;
例如,32位系统中进程的用户空间地址范围为0~0x7fffffff,64位系统中进程的用户空间地址范围是0~0x7ffffffffff。以进程“smss.exe”为例,根据地址范围直接得到smss进程的用户空间页面集合Vsmss_u={vsmss_addr|addr<0x7fffffff}。同理得到其他进程的用户空间页面集合,所有进程用户空间内存页面集合Vu=UprocVproc_u。
遍历所有虚拟内存页面,针对每个虚拟内存面执行页面映射t转换页面,若转换后的页面属于DLL代码模块物理内存页面集合Pe,则将该虚拟内存页面加入至虚拟内存页面集合Ve;遍历完成所有虚拟内存页面后即可得到最终的虚拟内存页面集合Ve。
具体地,操作系统为了节省物理内存占用,当同一个代码模块被多个进程使用时,会发生多个虚拟内存页面映射到同一个物理内存页面p的现象,所以映射t(v):V→P不存在逆映射。因此要找到物理内存页面p的原像只能遍历所有虚拟内存页面v并执行映射t(v)转换页面,遍历虚拟内存页面后得到代码模块物理页面对应的虚拟内存页面集合Ve={v|t(v)∈Pe}。
S105:逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;
具体地,针对每个进程,从其EPROCESS结构中读取PEB的指针,然后找到LDR链表,读取链表项得到每个进程的LDR链表中DLL代码模块虚拟内存页面集合Vproc_l;
计算所有进程的LDR链表中DLL代码模块虚拟内存页面集合Vproc_l的并集,即为DLL代码模块虚拟内存页面集合Vl。
例如,仍以系统进程“smss.exe”为例,逆向重建进程的LDR链表结构获取Vsmss_l的步骤如下:
如图7所示,在32位Win7系统的smss进程EPROCESS结构中读取PEB的虚拟地址为0x7ffdd000,由映射t(v):V→P访问该虚拟地址的数据并构建PEB结构,在PEB中读取LDR的虚拟地址为0x773f7880。LDR结构中包含三个双向链表InInitializationOrderModuleList、InMemoryOrderModuleList、InLoadOrderModuleList。以InInitializationOrderModuleList为例,该链表在LDR中偏移量为0xc,读取到相邻两个链表项的的虚拟地址为0x3b1790和0x3b1810。在该虚拟地址0x3b1790处构建_LDR_DATA_TABLE_ENTRY结构,读取代码模块的虚拟地址为0x484f0000,即vsmss_0x484f0000∈Vsmss_l。_LDR_DATA_TABLE_ENTRY结构开头是相邻两个链表项的虚拟地址,由此可以遍历InInitializationOrderModuleList链表。LDR中其他两个链表的结构具有相同的结构,可以按照同样的方法遍历并读取加载模块地址,最终得到Vsmss_l。
S106:比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
具体地,因为驱动模块与DLL文件有相同的文件头特征,因此集合Pe中包含了一部分驱动代码模块,但是驱动模块加载在虚拟内存的内核空间,并且不会出现在LDR链表中,检测时需要排除这些驱动模块所在页面。因此要得到用户空间代码模块虚拟内存页面集合Vu∩Ve。最后判断其中每个虚拟页面是否出现在集合Vl中,如果不在Vl中则该虚拟页面为隐蔽注入页面,即:v表示需要检测的虚拟内存页面。
本发明实施例还提供了相应的算法代码,如算法2所示:
本发明实施例提供的基于内存结构逆向分析的代码注入攻击取证检测方法,首先从物理角度在内存映像中基于DLL特征定位其对应的物理内存页面,设计了一种物理内存空间与虚拟内存空间映射算法,建立了映射关系t,实现了DLL代码模块对应的物理页面子集逆向重建机制。然后从虚拟内存空间着手,逆向重建进程的LDR链表结构,并设计了一种DLL虚拟页面子集逆向重建算法,实现了其虚拟空间重建。最后设计并实现了基于物理内存页面子集和虚拟空间页面子集的DLL注入攻击隐蔽页面检测算法。该方法在检测过程中不使用VAD结构,因此不受VAD属性篡改攻击的影响。在实践中本发明方法由于更高的准确度,适合作为检测隐藏内存页的首选方法,以快速确定取证分析的调查方向。
实施例2
对应上述的方法,如图8所示,本发明实施例还提供一种基于内存结构逆向分析的代码注入攻击取证检测系统,包括:预处理模块、物理定位模块、虚拟空间逆向构建模块和隐蔽页面识别模块;
其中,预处理模块用于对内存映像文件进行预处理,得到物理内存页面集合P。物理定位模块用于基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe。虚拟空间逆向构建模块用于逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;以及用于逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl。隐蔽页面识别模块用于根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;以及用于比较虚拟内存页面集合Ve、代码模块虚拟内存页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
需要说明的是,本发明实施例提供的系统是为了实现上述方法实施例的,其功能具体可参考上述方法实施例,此处不再赘述。
图9为本发明实施例提供的电子设备的结构框图。如图9所示,该电子设备包括:存储器902和处理器901,所述处理器901和所述存储器902通过总线903完成相互间的通信;所述存储器902存储有可被所述处理器执行的程序指令,所述处理器901调用所述程序指令能够执行如下方法,例如包括:对内存映像文件进行预处理,得到物理内存页面集合P;基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
本发明实施例还提供一种计算机程序产品,所述计算机程序产品包括存储在非暂态计算机可读存储介质上的计算机程序,所述计算机程序包括程序指令,当所述程序指令被计算机执行时,计算机能够执行上述各方法实施例所提供的方法,例如包括:对内存映像文件进行预处理,得到物理内存页面集合P;基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
本发明实施例还提供一种计算机可读存储介质,所述计算机可读存储介质存储计算机指令,所述计算机指令使所述计算机执行上述各方法实施例所提供的方法,例如包括:对内存映像文件进行预处理,得到物理内存页面集合P;基于DLL特征在物理内存页面集合P中定位得到DLL代码模块物理内存页面集合Pe;逆向重建虚拟内存空间以构建虚拟内存空间到物理内存空间的页面映射t;根据页面映射t,计算用户空间页面集合Vu并逆向查找得到物理内存页面集合Pe对应的虚拟内存页面集合Ve;逆向重建进程的LDR链表结构以获取DLL代码模块虚拟内存页面集合Vl;比较虚拟内存页面集合Ve、用户空间页面集合Vu和DLL代码模块虚拟内存页面集合Vl,得到隐蔽的注入DLL代码模块虚拟内存页面集合Vh。
为验证本发明方法和系统的有效性和通用性,本发明还提供有下述实验。
以新型代码注入攻击的Windows系统物理内存映像文件为实验对象。选取了Process Hollowing、Reflective DLL、VADRemapping三种注入技术的POC,以及Spyeye、Cridex和Zeus病毒作为测试样本,在不同版本的Windows系统中运行后获取内存映像文件,如表1所示。
对以上测试样本,将本发明方法同目前常用的检测方法(包括malfind、malthfind和Ptemalfind)进行对比实验,结果如表2和表3所示,其中进程准确率计算方法为正确报告的注入进程数/总报告进程数;页面准确率计算方法为正确报告的注入页面数/总报告页面数。其中malthfind检测的目标是线程,因此本实验将该插件报告的调用代码模块所在的页面作为其报告的隐藏页面。
表1实验样本
序号 | 样本名称 | 系统版本 |
1 | Process Hollowing | Win7SP0x86,内存1GB |
2 | Reflective DLL | Win7SP0x86,内存1GB |
3 | Spyeye | Win7SP1x64,内存1GB |
4 | VADRemapping | Win10_1903,内存2GB |
5 | Cridex | WinXPSP2x86,内存512M |
6 | Zeus | WinXPSP2x86,内存512M |
表2进程准确率
样本1 | 样本2 | 样本3 | 样本4 | 样本5 | 样本6 | 平均 | |
本发明方法 | 100% | 100% | 100% | 100% | 100% | 100% | 100.0% |
malfind | 25% | 33.3% | 42.9% | 0% | 96% | 50% | 41.2% |
malthfind | 0% | 100% | 60% | 0% | 100% | 100% | 60.0% |
Ptemalfind | 3.9% | 3.9% | 8.6% | 3.9% | \ | \ | 5.1% |
表3页面准确率
样本1 | 样本2 | 样本3 | 样本4 | 样本5 | 样本6 | 平均 | |
本发明方法 | 100% | 100% | 100% | 100% | 100% | 100% | 100.0% |
malfind | 20% | 25% | 40% | 0% | 79% | 17% | 30.2% |
malthfind | 0% | 100% | 60% | 0% | 100% | 100% | 60.0% |
Ptemalfind | 0.1% | 0.1% | 0.2% | 0.1% | \ | \ | 0.1% |
需要说明的是样本2实验中,Reflective DLL在注入时会先把载荷DLL文件作为数据直接读取到内存中,然后再次申请内存空间,重新以可执行代码的模式映射载荷代码模块,所以内存中存在两个注入模块,一个是文件数据页面,另一个是可执行的内存页。由于注入的数据页面通常会被释放,因此只把可执行的内存页面作为检测目标页面计入准确率,但是本发明方法仍然可以发现注入的数据页面作为系统可能被攻击的迹象。
malfind方法仅检测VAD节点的私有属性、保护属性,检测条件粗略导致准确率不高。在样本4中,由于VAD的属性被恶意篡改,导致malfind完全无法检测到注入页面。
malthfind方法基于重建调用栈以发现未知的调用模块,在检测运行中的恶意注入页面时有较高的准确率,如样本2、5、6,但是无法检测到未执行的潜在注入页面,如样本3和4中,部分注入页面没有执行而不存在调用栈,因此无法检测到。
Ptemalfind对样本5、6无法运行,原因是WinXP系统的PTE结构中缺少Ptemalfind检测需要的属性。同时发现该方法几乎可以检测到所有方法注入的内存页面,但是其准确率极低,导致在实践中难以应用。
本发明方法对6个实验样本都能完全检测出隐藏的注入页面,且没有误报,弥补了现有方法的不足。实验结果表明,本发明所述方法的准确率高于现有方法,并且能够准确检测到VADRemapping(样本4)技术注入的内存页面。
最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。
Claims (8)
1.一种基于内存结构逆向分析的代码注入攻击取证检测方法,其特征在于,包括:
步骤1:对内存映像文件进行预处理,得到物理内存页面集合P;
遍历所有虚拟内存页面,针对每个虚拟内存页面执行页面映射转换页面,若转换后的页面属于DLL代码模块物理内存页面集合/>,则将该虚拟内存页面加入至虚拟内存页面集合/>;遍历完成所有虚拟内存页面后即可得到最终的虚拟内存页面集合/>;
2.根据权利要求1所述的一种基于内存结构逆向分析的代码注入攻击取证检测方法,其特征在于,步骤1具体包括:
对内存映像文件进行解析后得到原始物理内存数据,按照4KB大小对所述原始物理内存数据进行分页管理,得到由若干个4KB内存页面组成的物理内存页面集合P。
4.根据权利要求1所述的一种基于内存结构逆向分析的代码注入攻击取证检测方法,其特征在于,步骤3具体包括:
步骤3.1:在EPROCESS中搜索已知进程的名称,根据搜索结果构建EPROCESS结构;
步骤3.2:采用_KUSER_SHARED_DATA结构验证所构建的EPROCESS结构是否正确;若正确,执行步骤3.3;
步骤3.3:从EPROCESS结构中读取进程的页表物理地址DTB值,进而由内存页表构建得到该进程的虚拟页面到物理页面的映射关系;
步骤3.4:根据EPROCESS结构中的ActiveProcessLinks获取与其相邻的两个EPROCESS结构的虚拟地址;
步骤3.5:根据已获取的进程的虚拟页面到物理页面的映射关系和相邻的两个EPROCESS结构的虚拟地址,构建得到相邻的两个新的进程EPROCESS结构;
6.一种基于内存结构逆向分析的代码注入攻击取证检测系统,其特征在于,包括:
预处理模块,用于对内存映像文件进行预处理,得到物理内存页面集合P;
隐蔽页面识别模块,用于根据页面映射,计算用户空间页面集合/>并逆向查找得到DLL代码模块物理内存页面集合/>对应的虚拟内存页面集合/>;具体用于:针对每个进程,根据进程的用户空间地址范围得到每个进程的用户空间页面集合;计算所有进程的用户空间页面集合的并集得到用户空间页面集合/>;遍历所有虚拟内存页面,针对每个虚拟内存面执行页面映射/>转换页面,若转换后的页面属于DLL代码模块物理内存页面集合/>,则将该虚拟内存页面加入至虚拟内存页面集合/>;遍历完成所有虚拟内存页面后即可得到最终的虚拟内存页面集合/>;
7.一种电子设备,其特征在于,包括:
存储器和处理器,所述处理器和所述存储器通过总线完成相互间的通信;所述存储器存储有可被所述处理器执行的程序指令,所述处理器调用所述程序指令能够执行如权利要求1至5任一所述的方法。
8.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至5任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211062373.2A CN115481397B (zh) | 2022-08-31 | 2022-08-31 | 基于内存结构逆向分析的代码注入攻击取证检测方法与系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211062373.2A CN115481397B (zh) | 2022-08-31 | 2022-08-31 | 基于内存结构逆向分析的代码注入攻击取证检测方法与系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115481397A CN115481397A (zh) | 2022-12-16 |
CN115481397B true CN115481397B (zh) | 2023-06-06 |
Family
ID=84422714
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211062373.2A Active CN115481397B (zh) | 2022-08-31 | 2022-08-31 | 基于内存结构逆向分析的代码注入攻击取证检测方法与系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115481397B (zh) |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2000074368A2 (en) * | 1999-06-01 | 2000-12-07 | Bsquare Corporation | Device driver platform layer |
CN104715201A (zh) * | 2015-03-31 | 2015-06-17 | 北京奇虎科技有限公司 | 一种虚拟机恶意行为检测方法和系统 |
CN104714831A (zh) * | 2015-03-31 | 2015-06-17 | 北京奇虎科技有限公司 | 一种检测虚拟机中的寄生进程的方法和装置 |
CN112395609A (zh) * | 2019-08-15 | 2021-02-23 | 奇安信安全技术(珠海)有限公司 | 应用层shellcode的检测方法及装置 |
-
2022
- 2022-08-31 CN CN202211062373.2A patent/CN115481397B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2000074368A2 (en) * | 1999-06-01 | 2000-12-07 | Bsquare Corporation | Device driver platform layer |
CN104715201A (zh) * | 2015-03-31 | 2015-06-17 | 北京奇虎科技有限公司 | 一种虚拟机恶意行为检测方法和系统 |
CN104714831A (zh) * | 2015-03-31 | 2015-06-17 | 北京奇虎科技有限公司 | 一种检测虚拟机中的寄生进程的方法和装置 |
CN112395609A (zh) * | 2019-08-15 | 2021-02-23 | 奇安信安全技术(珠海)有限公司 | 应用层shellcode的检测方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN115481397A (zh) | 2022-12-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108090346B (zh) | 一种基于数据流监控的代码复用攻击防御方法及系统 | |
US9876812B1 (en) | Automatic malware signature extraction from runtime information | |
Xu et al. | Polymorphic malicious executable scanner by API sequence analysis | |
US7779472B1 (en) | Application behavior based malware detection | |
EP2324424B1 (en) | Apparatus and method for handling page protection faults in a computing system | |
US7421587B2 (en) | Detecting computer programs within packed computer files | |
RU2541120C2 (ru) | Система и способ обнаружения вредоносных исполняемых файлов на основании сходства ресурсов исполняемых файлов | |
US20140189866A1 (en) | Identification of obfuscated computer items using visual algorithms | |
US7631356B2 (en) | System and method for foreign code detection | |
US9239922B1 (en) | Document exploit detection using baseline comparison | |
US9038161B2 (en) | Exploit nonspecific host intrusion prevention/detection methods and systems and smart filters therefor | |
US20160196427A1 (en) | System and Method for Detecting Branch Oriented Programming Anomalies | |
US11354409B1 (en) | Malware detection using locality sensitive hashing of API call sequences | |
Sylve et al. | Pool tag quick scanning for windows memory analysis | |
CN114143024B (zh) | 基于生成对抗网络的黑盒恶意软件检测对抗样本生成方法、系统、电子设备及存储介质 | |
EP3087527B1 (en) | System and method of detecting malicious multimedia files | |
Case et al. | Memory analysis of macos page queues | |
CN115481397B (zh) | 基于内存结构逆向分析的代码注入攻击取证检测方法与系统 | |
CN115509960A (zh) | 一种基于页表条目的shellcode注入检测方法 | |
CN115964758A (zh) | 一种基于TrustZone的内核数据完整性保护方法 | |
Pék et al. | Membrane: a posteriori detection of malicious code loading by memory paging analysis | |
Srivastava et al. | Detecting code injection by cross-validating stack and VAD information in windows physical memory | |
CN110674501B (zh) | 恶意驱动检测方法、装置、设备及介质 | |
US8732442B2 (en) | Method and system for hardware-based security of object references | |
Feifei | The principle and prevention of windows buffer overflow |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20230310 Address after: 450000 Science Avenue 62, Zhengzhou High-tech Zone, Henan Province Applicant after: Information Engineering University of Strategic Support Force,PLA Address before: 450000 Science Avenue 62, Zhengzhou High-tech Zone, Henan Province Applicant before: Information Engineering University of Strategic Support Force,PLA Applicant before: Henan Yunyan Technology Co.,Ltd. |
|
TA01 | Transfer of patent application right | ||
GR01 | Patent grant | ||
GR01 | Patent grant |