WINDOWS2003 内核级进程隐藏、侦测技术.doc_第1页
WINDOWS2003 内核级进程隐藏、侦测技术.doc_第2页
WINDOWS2003 内核级进程隐藏、侦测技术.doc_第3页
WINDOWS2003 内核级进程隐藏、侦测技术.doc_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

文章来源 毕业论文网 windows2003 内核级进程隐藏、侦测技术文章来源 毕业论文网 论文关键字: 内核拦截活动进程链表系统服务派遣表线程调度链 驱动程序简介  论文摘要:信息对抗是目前发展的一个重要的方向,为了更好的防御,必须去深入的了解敌人进攻的招式。信息对抗促使信息技术飞速的发展。下面我选取了信息对抗技术的中一个很小一角关于windows内核级病毒隐藏技术和反病毒侦测技术作为议题详细讨论。 1.为什么选驱动程序 驱动程序是运行在系统信任的ring0下在代码,她拥有对系统任何软件和硬件的访问权限。这意味着内核驱动可以访问所有的系统资源,可以读取所有的内存空间,而且也被允许执行cpu的特权指令,如,读取cpu控制寄存器的当前值等。而处于用户模式下的程序如果试图从内核空间中读取一个字节或者试图执行像mov eax,cr3这样的汇编指令都会被立即终止掉。不过,这种强大的底线是驱动程序的一个很小的错误就会让整个系统崩溃。所以对隐藏和反隐藏技术来说都提供了一个极好的环境。但是又对攻击者和反查杀者提出了更高的技术要求。 2.入口例程driverentry driverentry是内核模式驱动程序主入口点常用的名字,她的作用和main,winmain,是一样的。 extern “c” ntstatus driverentry(in pdriver_object driverobject, in punicode_string registrypath).driverentry的第一个参数是一个指针,指向一个刚被初始化的驱动程序对象,该对象就代表你的驱动程序,driverentry的第二个参数是设备服务键的键名。driverentry函数返回一个ntstatus值。ntstatus实际就是一个长整型,但你应该使用ntstatus定义该函数的返回值而不是long,这样代码的可读性会更好。大部分内核模式支持例程都返回ntstatus状态代码,你可以在ddk头文件ntstatus.h中找到ntstatus的代码列表。 driverentry的作用主要就是创建设备对象,建立设备对象的符号链接,设置好各个类型的回调函数等。 例如: extern “c” ntstatus driverentry(in pdriver_object driverobject, in punicode_string registrypath)  driverobject->driverunload = driverunload;                                                             <-1  driverobject->driverextension->adddevice = adddevice;  driverobject->driverstartio = startio;  driverobject->majorfunctionirp_mj_pnp = dispatchpnp;                                        <-2  driverobject->majorfunctionirp_mj_power = dispatchpower;  driverobject->majorfunctionirp_mj_system_control = dispatchwmi;  . 在wdm中通过设置adddevice回调函数来创建设备对象。在nt驱动中在driverentry例程中创建设备对象和符号链接。 例如: rtlinitunicodestring (&devicenameunicodestring, devicenamebuffer); /初始化设备名字/创建设备 ntstatus = iocreatedevice (driverobject,                                  0,                             &devicenameunicodestring,                             #deviceid,                             0,                             false,                             &deviceobject                             ); if ( nt_success ( ntstatus ) )       rtlinitunicodestring (&devicelinkunicodestring, devicelinkbuffer); /初始化符号链接名字 /创建符号链接    ntstatus = iocreatesymboliclink (&devicelinkunicodestring, &devicenameunicodestring);    if ( !nt_success ( ntstatus ) )         iodeletedevice (deviceobject); /如果创建符号链接失败,删除设备             return ntstatus; 建立符号链接的作用就是暴露一个给应用程序的接口,应用程序可以通过createfile api打开链接符号,得到一个语柄,和我们的驱动程序进行交互操作。3.unload例程 虽然各个驱动程序的unload例程不尽相同,但是它大致执行下列工作: 释放属于驱动程序的任何硬件。 从win32的名字空间移除符号连接名。 这个动作可以调用iodeletesymboliclink来实现。 使用iodeletedevice移除设备对象。 释放驱动程序持有的任何缓冲池等。 void driverunload ( in pdriver_object pdriverobject ) pdevice_object pnextobj; / 循环每一个驱动过程控制的设备 pnextobj = pdriverobject->deviceobject; while (pnextobj != null) /从设备对象中取出设备extension pdevice_extension pdevext = (pdevice_extension)extobj->deviceextension; / 取出符号连接名 unicode_string plinkname = pdevext->ustrsymlinkname; iodeletesymboliclink(&plinkname); /删除符号连接名 iodeletedevi

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论