原文链接:抢先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. TCP/IP详解之:TCP

    第17章 TCP:传输控制协议 TCP提供了一种可靠的面向连接的字节流运输层服务 TCP的服务 尽管TCP和UDP都使用相同的网络层(IP),TCP却向应用层提供与UDP完全不同的服务. TCP通过下 ...

  2. C语言基础04

    什么叫数组呢?我们的第一反应是很多数组合在一起就是数组,字面意思,当然不仅仅是数字,字符也是可以的. 数组属于构造类型 .指相同类型的若干变量组织起来. 类型说明符 数组名 [常量表达式] int   ...

  3. oracle面试

    1. Oracle跟SQL Server 2005的区别? 宏观上: 1). 最大的区别在于平台,oracle可以运行在不同的平台上,sql server只能运行在windows平台上,由于windo ...

  4. DataTables warning 错误警告

    今天使用 Charisma 框架的 jquery datatable 插件时出现如下错误: 搜索才发现 DataTables 目前不支持有单元格合并的表格.而且只要单元格数目不同就会有错误,不能使用搜 ...

  5. Es分析

    http://my.oschina.net/lxbzj/blog/138587 http://donlianli.iteye.com/blog/1923017 http://tangzhaohui.n ...

  6. Android 使用PopupWindow实现弹出菜单

    在本文当中,我将会与大家分享一个封装了PopupWindow实现弹出菜单的类,并说明它的实现与使用. 因对界面的需求,android原生的弹出菜单已不能满足我们的需求,自定义菜单成了我们的唯一选择,在 ...

  7. C语言中为什么不能把char**赋给const char**

    这是我在知乎回答的一个问题. 这个问题是C中的一个深坑,首先说结论: char ** 和 const char ** 是两个不相容(incompatible)的类型,能够理解为不能直接赋值 在C11的 ...

  8. Repeater的ItemCommand事件和ItemCreated事件,高手请跳过~

    捣鼓这几天,我终于比之前更能区别Repeater的ItemCommand事件和ItemCreated事件了 当Repeater的dataSource是sqldataSource的话,要想触发ItemC ...

  9. JavaScript引用类型之RegExp类型(正则表达式)

    ECMAScript中使用RegExp来支持正则表达式.使用下面类似Perl的语法,就可以创建一个正则表达式. var expression=/pattern/flags; 如上代码: pattern ...

  10. node.js(七) 子进程 child_process模块

    众所周知node.js是基于单线程模型架构,这样的设计可以带来高效的CPU利用率,但是无法却利用多个核心的CPU,为了解决这个问题,node.js提供了child_process模块,通过多进程来实现 ...