



免费预览已结束,剩余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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 冬期施工方案(中建六局最 新版)
- 美国介绍课件
- 2025浙江丽水市松阳县“乡村运营师”人才引进1人考试参考题库附答案解析
- 2025宁波市奉化区部分机关事业单位编外招聘69人考试参考题库附答案解析
- 2025湖南郴州市宜章县城区学校教师选聘选岗132人笔试参考题库附答案解析
- 广元市消防员招录工作办公室开展2025年度国家综合性消防救援队伍消防员招录体格检查考试模拟试题及答案解析
- 2025年四川省科技交流中心考核招聘事业编制工作人员2人考试备考试题及答案解析
- 2025甘肃天水清水县盛农农业产业发展有限责任公司招聘工作人员3人笔试参考题库附答案解析
- 2025年甘肃省临夏州临夏市供排水公司人员招聘考试模拟试题及答案解析
- 2025南平浦城县公安局辅警招聘10名考试参考题库附答案解析
- 2025年湖北省中考语文真题(含答案)
- 2025年四川三支一扶考试公共基础知识试卷
- 战术基础动作低姿匍匐
- 2025年公文核改竞赛试题及答案
- 2025年秋季学期开学第一次中层班子会上校长精彩讲话:向小处看往实里干朝远处谋
- 有机硅行业面试攻略:高级岗位面试题库
- 2025历年退役军人考试题库及答案
- 第一二单元月考综合试卷(试题)四年级上册数学沪教版
- 2025级新生军训开训仪式动员大会
- 农产品质量安全标准体系与实施路径-洞察及研究
- 专利分级管理办法
评论
0/150
提交评论