原文链接:抢先DriverStudio夺取机器控制权

废话不谈,言归正传!大家都知道,装了DriverStudio软件(我使用的是v3.2版)的系统在启动时会显示其配置画面,(如图0所示)

图 0

这时操作系统的其他部件还没有运行。那么显示的原理是什么?能不能早于DriverStudio而先执行其他代码呢?答案是肯定的。下面先谈谈原理吧。

原理比较简单,详细的大家可以看网文<<Inside NT boot>>,我这里简单说说。当引导扇区被引导后,会查找NTLDR,NTLDR做的一件非常重要的事就是将CPU从实模式转换到保护模式下。在加载完NTDECT.COM后接下来就会将NT的核心装入内存,它们是HAL.DLL和NTOSKRNL.EXE,加载完毕后,NTLDR再加载所有引导必须的驱动程序。接下来就是我们所关心的地方:它会将HKLM/SYSTEM/Services中值为 SERVICE_BOOT_START的DRIVER装入,但此时不初始化。

(补充附注:NtLdr第3步动作:扫描内存中SYSTEM注册表hive文件找到所有引导设备驱动程序,这些Driver仔注册表中通过SERVICE-BOOT-START启动值标记。

NtLdr第5步动作:加载引导驱动程序,在启动画面StartingWindows下显示出不断更新的进度栏,该进度栏随每个驱动程序的加载而变化。

Kernel第23步动作:I/O管理器初始化……所有前面加载的Boot-Start型驱动程序被调用以完成驱动程序相关初始化,这时才轮到System-Start型的驱动程序被加载并初始化。更详细的信息请参考<<Windows 2000 内部揭秘>>)

那么DriverStudio是不是也是使用了这个特性呢?运行 regedit.exe ,在Services目录中找到bootcfg这个注册项,可以看到它是一个内核驱动,并且Start类型为0。如图1所示:

图1

为了证实这个Driver就是提供DriverStudio开机时配置功能的驱动程序,我用一个会引起系统崩溃驱动的名字来替换它,然后重新启动。原本该显示配置画面的地方果然发生了系统崩溃。(如图2所示)

图 2

既然知道了原理,再来看看操作。实际上windows自身提供了这个实现。细心的朋友可能早就知道Win32 APICreateService的dwStartType 形参有个选项为:SERVICE_BOOT_START 。

SERVICE_BOOT_START  --  Specifies a device driver started by   the operating system loader. This value is valid only if the    service type is SERVICE_KERNEL_DRIVER or SERVICE_FILE_SYSTEM_DRIVER.

好像看起来和普通的诸如SERVICE_DEMAND_START  的用法没什么不同嘛,结果手动编制尝试结果返回非法参数。

为什么会这样呢?经过一番thinking之后,我猜测由于使用了SERVICE_BOOT_START 时,是在系统引导的早期发生loadDriver事件,这时可能除了少数几个OS必须的路径以外,还无法访问其他windows目录。为了证实,我将自己的Driver拷贝到系统目录:

%root%/system32/drivers/

下,再次运行结果成功!下面再引出注册表中的一个与驱动程序加载相关的KEY:ServiceGroupOrder ,如图3所示:

图3

再看一下图1中DriverStudio引导驱动的组名,是Boot Bus Extender,它排在启动顺序的第2位。现在我新加一个Group名:Hopy。如图4:

图4

然后将代码改写如下:

 ;BTmain.asm节选

 .const

 namesvr    db 'TryBootSvr',

 notesvr    db 'Test Drv Start at System Boot',

 namefile db 'BTdrv.sys',

 szLOG   db 'hopy',

 szSSN   db 'TBSvr2007',       ;ServiceStartName

 szpath     db 'C:/WINNT/system32/drivers/BTdrv.sys',

 .code

 invoke  CreateService,hSCM,addr namesvr,addr notesvr,/

       SERVICE_ALL_ACCESS,SERVICE_KERNEL_DRIVER,/

       SERVICE_BOOT_START,SERVICE_ERROR_NORMAL,/

       addr szpath,addr szLOG,addr tagid,NULL,/

       NULL,NULL

 驱动代码如下:

 ;BTdrv.asm节选

 local status:NTSTATUS

    local pDeviceObject:PVOID

    mov   status, STATUS_DEVICE_CONFIGURATION_ERROR

    xor   edi,edi

    mov   [edi],eax

    jmp   $

    mov   eax,status

    ret

结果如我们所预料,该Driver抢在DriverStudio之前发生蓝屏,如果将这个Driver换成带有特定功能的代码的驱动,则可以实现超前的目的。这个留给大家去想象吧,呵呵。

大熊猫侯佩

2007.09.16 写于中国

女足惨败于巴西之后

[原创]抢先DriverStudio夺取机器控制权(上篇)的更多相关文章

  1. [原创]抢先DriverStudio夺取机器控制权(下篇)

    原文链接:抢先DriverStudio夺取机器控制权(下篇) 上篇仅仅说到如何抢先DriverStudio,并在结尾留给大家一个遐想.现在我进一步拓展这个遐想,从而给大家更多的遐想.: ) 那么现在我 ...

  2. 【百度SEO优化】如何让蜘蛛爬行你的网站

    大家都知道,现在做网站简单,但是推广就比较困难了,可能一些商家引入投资,直接烧钱做广告来推广,但是对于一些小站长,是没有那么多资金的.因此我们就要懂得一些SEO优化的知识了,简单介绍一下: 怎么让百度 ...

  3. Hacker(25)----病毒攻防之认识病毒

    Internet中,计算机病毒是威胁计算机安全的程序.对于计算机病毒,用户不仅需要掌握其基础知识,还要认识常见的病毒及简单病毒制作方法.无论病毒基础还是制作简单病毒,用户需要掌握防御病毒的有效措施和专 ...

  4. Hacker(十一)----黑客常用入侵方法

    Internet中,为了防止黑客入侵自己的电脑,就必须了解黑客入侵目标计算机的常用方法.黑客常用的入侵方法有数据驱动攻击.系统文件非法利用.伪造信息攻击.远端操纵等. 一.数据驱动攻击 数据驱动攻击是 ...

  5. 用Delphi实现Windows的鼠标钩子函数

    Delphi是基于PASCAL语言的Windows编程工具,功能十分强大.然而在Delphi的帮助文件中,对Windows API函数的说明沿袭了 VC 的格式,和VC一样,对很多API函数的用法没有 ...

  6. CRC 校验

    匠心零度 转载请注明原创出处,谢谢! 说明 上篇RocketMQ(二):RPC通讯介绍了rocketmq的一些rpc细节,其实这些内容不仅仅是rocketmq内容,任何通信模块基本都是类似的,这块内容 ...

  7. (转) 深度强化学习综述:从AlphaGo背后的力量到学习资源分享(附论文)

    本文转自:http://mp.weixin.qq.com/s/aAHbybdbs_GtY8OyU6h5WA 专题 | 深度强化学习综述:从AlphaGo背后的力量到学习资源分享(附论文) 原创 201 ...

  8. Linux内核分析方法谈

    本文来自 http://blog.csdn.net/ouyang_linux007/article/details/7422346 Linux的最大的好处之一就是它的源码公开.同时,公开的核心源码也吸 ...

  9. [原创]Oracle 12c 抢先安装手迹

    [前言] Oracle 12c 终于投放市场了,唉,等了很久了.据官方说这是一个为云计算平台量身定做的版本....且不管真的假的,先让我们把它装上再说. 注:笔者在安装的过程中发现12c的安装过程,较 ...

随机推荐

  1. Windows计算器使用详解

    (1)Backspace:退格,删除当前输入数字中的最后一位 (2)CE:清除,清除显示的数字. (3)C:归零,清除当前的计算. (4)MC:清除存储器中的数值. (5)MR:将存于存储器中的数显示 ...

  2. Gabor滤波器学习

    本文的目的是用C实现生成Gabor模版,并对图像卷积.并简单提一下,Gabor滤波器在纹理特征提取上的应用. 一.什么是Gabor函数(以下内容含部分翻译自维基百科) 在图像处理中,Gabor函数是一 ...

  3. Oracle 添加 scott 示例用户

    学习SQL有一段时间了,但是也忘记的差不多了,今天有赶紧复习复习,然后发现一个问题,为啥之前看的视频教程,马士兵用的Oracle有scott用户和那些表格,而我的没有?难道是Oracle取消了?然后百 ...

  4. 整数转字符与字符转整数的C系统函数

    atoi (表示 alphanumeric to integer)是把字符串转换成整型数的一个函数 http://baike.baidu.com/link?url=VTP54JT5-EY5TL0GFf ...

  5. MUD教程--巫师入门教程3

    1. 指令格式为:edit <档名>,只加文件名,默认为当前目录,加here,表示编辑你当前所处的房间, 回车后即进入线上编辑系统. 2. 如果这是一个已经有的档案,你可以使用 z 或 Z ...

  6. jQuery学习-事件之绑定事件(五)

    大家应该还记得dispatch方法中有这么一段代码: event = jQuery.event.fix( event ); event的修复是在fix这个方法中的,而在fix中是通过 new jQue ...

  7. ubuntu下C编程,编译基础( 转)

    buntu下C编程,编译基础     C 编程中相关文件后缀 .a 静态库 (archive) .c C源代码(需要编译预处理) .h C源代码头文件 .i C源代码(不需编译预处理) .o 对象文件 ...

  8. 通过jpegoptim批量压缩文件

    #!/bin/sh filelist=$(ls) for file in $filelist do if [ -d $file ] then du -h $file /usr/local/bin/jp ...

  9. 《小C QQ空间转帖、分享工具》之QQ空间数据传递的g_tk算法(C#)

    原文地址:http://user.qzone.qq.com/419067339/2 public string GET_HTTP(string url, string referer_post, st ...

  10. poj3429(有错)

    不知道为什么错.. /************************************************************************* > File Name: ...