Windows2003 内核级进程隐藏、侦测技术_计算机论文.docVIP

Windows2003 内核级进程隐藏、侦测技术_计算机论文.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Windows2003 内核级进程隐藏、侦测技术_计算机论文.doc

Windows2003 内核级进程隐藏、侦测技术_计算机论文 Windows2003 内核级进程隐藏、侦测技术_计算机论文 论文关键字:内核 拦截 活动进程链表 系统服务派遣表 线程调度链驱动程序简介   论文摘要:信息对抗是目前计算机发展的一个重要的方向,为了更好的防御,必须去深入的了解敌人进攻的招式。信息对抗促使信息技术飞速的发展。下面我选取了信息对抗技术的中一个很小一角关于windows内核级病毒隐藏技术和反病毒侦测技术作为议题详细讨论。   1.为什么选驱动程序   驱动程序是运行在系统信任的Ring0环境下在代码,她拥有对系统任何软件和硬件的访问权限。这意味着内核驱动可以访问所有的系统资源,可以读取所有的内存空间,而且也被允许执行CPU的特权指令,如,读取CPU控制寄存器的当前值等。而处于用户模式下的程序如果试图从内核空间中读取一个字节或者试图执行像MOVEAX,CR3这样的汇编指令都会被立即终止掉。不过,这种强大的底线是驱动程序的一个很小的错误就会让整个系统崩溃。所以对隐藏和反隐藏技术来说都提供了一个极好的环境。但是又对攻击者和反查杀者提出了更高的技术要求。   2.入口例程DriverEntry   DriverEntry是内核模式驱动程序主入口点常用的名字,她的作用和main,WinMain,是一样的。   externCNTSTATUSDriverEntry(INPDRIVER_OBJECTDriverObject,INPUNICODE_STRINGRegistryPath)   {...}   DriverEntry的第一个参数是一个指针,指向一个刚被初始化的驱动程序对象,该对象就代表你的驱动程序,DriverEntry的第二个参数是设备服务键的键名。DriverEntry函数返回一个NTSTATUS值。NTSTATUS实际就是一个长整型,但你应该使用NTSTATUS定义该函数的返回值而不是LONG,这样代码的可读性会更好。大部分内核模式支持例程都返回NTSTATUS状态代码,你可以在DDK头文件NTSTATUS.H中找到NTSTATUS的代码列表。   DriverEntry的作用主要就是创建设备对象,建立设备对象的符号链接,设置好各个类型的回调函数等。   例如: externC NTSTATUS DriverEntry(INPDRIVER_OBJECTDriverObject,INPUNICODE_STRINGRegistryPath) { DriverObject-gtDriverUnload=DriverUnload--1 DriverObject-gtDriverExtension-gtAddDevice=AddDevice DriverObject-gtDriverStartIo=StartIo DriverObject-gtMajorFunction[IRP_MJ_PNP]=DispatchPnp--2 DriverObject-gtMajorFunction[IRP_MJ_POWER]=DispatchPower DriverObject-gtMajorFunction[IRP_MJ_SYSTEM_CONTROL]=DispatchWmi ... }   在WDM中通过设置AddDevice回调函数来创建设备对象。在NT驱动中在DriverEntry例程中创建设备对象和符号链接。   例如:   RtlInitUnicodeString(ampdeviceNameUnicodeString,deviceNameBuffer)//初始化设备名字 //创建设备 ntStatus=IoCreateDevice(DriverObject, 0, ampdeviceNameUnicodeString, ##DeviceId, 0, FALSE, ampdeviceObject ) if(NT_SUCCESS(ntStatus)){ RtlInitUnicodeString(ampdeviceLinkUnicodeString,deviceLinkBuffer)//初始化符号链接名字 //创建符号链接 ntStatus=IoCreateSymbolicLink(ampdeviceLinkUnicodeString,ampdeviceNameUnicodeString) if(!NT_SUCCESS(ntStatus)){ IoDeleteDevice(deviceObject)//如果创建符号链接失败,删除设备 returnntStatus } }   建立符号链接的作用就是暴露一个给应用程序的接口,应用程序可以通

文档评论(0)

wyj199216 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档