原文链接:抢先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. asp.net 两个页面之前传递数据

    .在两个表单之间传递数据 看下面的代码: 对于WebForm1: private void Page_Load(object sender, System.EventArgs e) { ArrayLi ...

  2. 算法竞赛中G++编译器的编译指令简单说明

    算法竞赛使用的在线判题平台在FAQ会给出提交的代码是通过什么指令进行编译的.比如hustoj给出的c++编译指令通常是: C++: g++ Main.cc -o Main -fno-asm -O2 - ...

  3. Ubuntu14.04如何备份和恢复系统

    清理Ubuntu14.04的系统的垃圾:先清空回收站,软件升级到最新.Ubuntu系统与Windows系统所采用的文件系统不同, Ubuntu系统在使用或更新过程中不会产生文件碎片和垃圾文件,所以在使 ...

  4. android Mvp简单实用

    View 对应于Activity,负责View的绘制以及与用户交互Model 依然是业务逻辑和实体模型Presenter 负责完成View于Model间的交互 模拟客户端的登录操作,并实现登录成功与登 ...

  5. javascript实现当前页导航激活

    html <ul id=”nav”> <li><a href=”http://www.daqianduan.com/”>首页</a></li> ...

  6. Django模板-分离的模板

    上一篇Django模板-在视图中使用模板最后的问题,我们需要把数据和展现分离开. 你可能首先考虑把模板保存在文件系统的某个位置并用 Python 内建的文件操作函数来读取文件内容. 假设文件保存在 E ...

  7. 使用plist的好处

    首先:帮助节省内存.OpenGL ES纹理要求宽和高都是2的n次幂的倍数.我们可以考虑将小的图片拼大图片,然后统一加载.  其次:提高渲染速度.OpenGL ES要求切换的纹理越少越好,将图片拼成大图 ...

  8. Delphi 实现任务栏多窗口图标显示

    uses Windows; type TfrmLogin = class(TForm) end; implementation {$R *.dfm} procedure TfrmLogin.FormC ...

  9. yum localinstall rpm

  10. SVG 教程

    SVG 意为可缩放矢量图形(Scalable Vector Graphics). SVG 使用 XML 格式定义图像. 现在开始学习 SVG! <html> <body> &l ...