64位驱动签名工具64Signer

【作者:张佩】【原始URL:http://www.yiiyee.cn/Blog/64signer/

注,此工具业已过时,无存在之必要。许多人想寻求稳妥的64位系统之签名绕过方法,此处做统一回复,没有可能。唯文中所涉及之技术点,犹可供参考。删除下载链接,而留此文。

  • 背景介绍

微软对于自Vista开始的64位OS有新的数字签名策略,即所有内核驱动都必须是经过可信机构签发过数字证书的,否则系统拒绝加载,其目的是为了加强系统安全防护,使得一干惯于偷偷摸摸、不知所自何来的内核模块无法在系统中容身。但它却也给正经的内核开发人员带去了一个麻烦:开发过程中会不断生成新的驱动镜像文件,开发者不可能将每一个内部版本都拿去申请数字签名,那样不仅太麻烦,而且会大大延长开发周期。

微软当然也考虑到了这一点,它提供了一个可以禁止签名检验的开机启动项。要运用此启动项,用户必须在启动电脑的时候,及时在键盘上按下F8键,在出来的启动菜单中选择倒数第二个启动项:Disable Driver Signature Enforcement.

这看上去很省心,但你如果再了解得深入一点,就会发现它其实很麻烦。

首先开机启动项只能手动选择,系统再次重启的时候,它会忘记上一次所选择的启动项,用户如果不再次及时按下F8按钮的话,就会错过机会,只能谋求下一次重启时的机会。如果开发者需要不断地进行重启测试的话,就必须有一个专人站在边上,作用就是及时地按下F8并在出现的启动菜单中选择倒数第二项。这是很无聊并痛苦的事情,所以大多数开发者不愿采用这种方法。

其次就是在Win8系统上,用户在系统开机时已没有通过F8调出启动菜单的机会。这一点虽然可以避免,但过程却也复杂,这里不展开介绍。

看到一扇关闭的窗户,不必急着沮丧,或许旁边正有一扇为你敞开的大门。微软还提供了一项称为Test Sign的技术,却正可以较好解决内核开发者的这项困扰。只不过它的实现方法比较复杂,虽然微软提供了详细的文档,但不到万不得已,开发者一般不会去详细研究其内容。从步骤上来讲,这个技术分两个实现步骤:

首先,启动Test Signing启动项属性。实现的一个简单方法是在控制台中运行如下命令:

Bcdedit /set testsiging true

此命令的意思是为当前系统启动项打开名为“TestSigning”的属性。如果再运行下面的命令,就能看到这个属性被列出:

Bcdedit /enum {current}

bcd-testsigning

这个属性会在下次系统重启时生效。系统会一直记住这个属性,重启系统后也依然有效。

第二是用一个测试证书对你的内核镜像文件(一般即.sys文件)进行签名。用户对此可能有点困惑,稍微介绍一下。原来如果认证机构为内核驱动签名的时候,会颁发一个受信证书,这个证书最终会安装到用户系统中,而对镜像文件所进行的签名操作,就是把证书信息写到文件中。系统通过验证这个证书来确认其受信与否。获取这个证书首先需要银子,其次也需要时间。但如果我自己能够给自己颁发一个临时证书,又怎样呢?那当然又省心又快捷了。微软提供了这样的策略:在Test Signing模式下,测试证书能和其它商业证书一样工作无误。

那么这第二个步骤其实又能细分为两个小步骤:1. 创建测试证书;2.用测试证书为驱动签名。微软提供了相关工具,包含在最新的SDK或DDK中。简单来讲,用户应该使用makecert.exe创建证书,再用signtool.exe进行镜像文件签名。微软所提供的工具不止这两个,但这两个确实是最重要的。遗憾的是这些工具都只能运行在控制台中,用户界面不算友好,参数也很晦涩。这大概是为什么大多数内核开发者都不太使用这些工具的原因?

工具使用方法,请参考微软相关文档。

  • 使用64Signer

64signer

好了,现在一个崭新的新星出现了。64Signer能帮助你一步到位。它不仅界面清晰明了,并且功能完整智能。开发者只要简单地进行一次拖拽,点最多两个按钮,就可以完成系统设置和文件签名等一系列的工作。深渊隐藏在坚实的桥面下,用户只需开车通过,而无需流连惊骇

工具的操作方法其实已简单明了地列在界面上(红色字体部分),但我还是愿意详细解释一下使用过程:

  1. 运行工具后它能够正确显示当前系统的Test Signing设置。如果此属性已被打开,则“Enable Test Signing Option”是自动钩住的;否则用户需点击一下(第一个点击)。
  2. 然后用户应将驱动文件拖拽到用户界面中来,或者手动输入路径,或者点击Open按钮从而通过文件对话框来选择,都可以(一次拖拽)。
  3. 64Signer_success最后点击Sign按钮(二次点击)。如果签名成功,用户能看到如右图所示提示成功的对话框。
  • 读者如果看到有失败的情况,请发邮件告诉我。

64Signer_reboot

在关闭工具的时候,工具如果检测到你改变了Test Signing启动属性,会有如右图所示的系统重启提示。

整个过程就这么简单,我总结为:一拖两点。

这个工具的贴心之处还没有完全展现出来,如果你看到曾经操作过的历史文件已被整理妥当,以动态列表的形式显示,而你只要点击一下就能展开并选择,贵用户的心情会不会更开心?如下图所示:

64Signer_fileList

 补充

在有些启用了Secure Boot的机器上,不能打开TestSigning启动选项。这种情况下,64Signer就不能使用了。下面是一个例子:

C:\windows\system32>bcdedit /set {current} testsigning on
An error has occurred setting the element data.
The value is protected by Secure Boot policy and cannot be modified or deleted.

59,875 total views, 11 views today

《64位驱动签名工具64Signer》有69个想法

  1. 你好 使用你的工具软件签名提示成功,在Testmode模式下安装时候,还是提示没有数字签名,,,,

    1. 64Signer到目前为止没遇到过不成功的情况。你是什么系统?被签名的文件上,右键看属性,有“数字签名”属性页吗?
      必要时,我可以远程帮你看一下。

      1. 你好!请问下现在WIN10 64位 可以用吗?? 我有哥驱动 是虚拟的MULTIKEY.SYS WIN7 64位 好用, WIN10 就是装不上 需要签名!

  2. 谢谢你了 , 昨天我重新试了,虽然提示没有数字签名但是安装成功了, 非常感谢。不过我们公司部不叫我使用这个工具, 说叫我自己写一个工具。能不能发一些关于如何伪造签名的详细步骤资料呢!

    1. 你简直莫名其妙。你把问题弄清楚了,再写comment不好吗?我现在也不知道你到底能用64Signer不能?64系统上,一定要有数字签名才能够使用。你又说签名不成功,又说驱动安装成功。这是自相矛盾的。你能确认好了再来吗?不要把模棱两可的信息推给别人。64Signer已经有几百个人成功使用过,如果你真碰到了问题,我很高兴看一下。

      TestSign不是伪造签名,它的名字就叫Test Sign,MS提供了工具SignTool.exe,MSDN上就有介绍文档,通过搜索引擎,你能找到更多资料。你可以直接使用SignTool。

  3. 你那有没有使用微软提供的工具进行签名的例子呢, 如果方便可以给提供一个么?我的windows 7 64位系统。

  4. 你好,我是用了dseo和64signer,对WDK7600中的SRC目录下编译后的驱动例子,进行签名,总是提示失败,让我看日志,我也没找到日志在那里,不知道为啥?

    1. 你不一定要用WDK编译出来的sys文件,任意一个镜像文件(.exe/.msi/.dll/.sys)都可以被签名。会遇到问题吗?可以的话,给我发封邮件,我看能不能远程到你的主机上看一下。

      1. 你好 我是通过 signtool sign /a XXX.sys 签名成功后,在用signtool verify XXX.sys 测试的时候报错,说证书不受信任的信任提供者。

  5. 很好用,我的智能手机的驱动安装成功,展讯芯片的,感叹号没有了。重启电脑后也不需要签名啦。彻底摆脱重启电脑按F8

  6. 我64位的WIN7系统终于可以用原厂平台刷机啦,再这里很感谢张佩老师开发的工具,这个工具用起来简单,实用,方便。就是右下角有个水印,怎么解决呢

  7. 张老师,您好,我用SignTool.exe签名了SYS和DLL,但是每次在WIN8-64位安装的时候仍然会报52的错,请问您能提供一些帮助吗?

  8. 张老师您好,我使用64signer给我的sys文件签名,无论是否Enable Test signing option选项都显示签名成功但是我用driver monitor安装我的驱动程序的时候,显示的是:“无法验证此文件的数字签名。某软件或硬件最近有所更改,可能安装了签名错误或损毁的文件,或者安装的文件可能是来路不明的恶意软件。”请问这个应该如何解决

      1. 买的是信任机构颁发的证书,驱动在安装时也能显示证书信息,安装后在设备管理器中发现sys文件未签名这个什么情况

        1. 微软有一个针对SHA2证书的补丁,会引起特定平台下签名失败的情况。你可以在网上搜一下,看是否有类似情况。

          1. 这是可参考的关于SHA-2证书的讨论:https://social.technet.microsoft.com/Forums/en-US/e97929e9-6451-499d-b56f-109f67489887/is-there-an-update-that-enables-sha2-certificates-for-win7?forum=w7itprosecurity

  9. 给sys文件签名了,右键属性能看到数字签名选项,但电子邮件和时间戳显示”不可用”,设备管理器仍然显示驱动未签名.求帮助!!!

  10. 你好,我的电脑是DELL 14-N4050 ,win7家庭普通版,用了64signer,驱动也签名了,也设置test signing 了,桌面右下角有水印,可驱动还是一直加载不上,bcdedit 查test sign是yes,不知道是什么原因呢?

      1. 这应该是code出错,你如果是用KMDF编写的驱动,调试AddDevice和EvtPrepareHardware两个函数,它们如果失败,驱动加载不成功。

  11. 这个根本就不能用啊,出错之后提示查看日志。又是骗人的东西,我不知道你说的“从来没遇到问题”是什么情况。简直傻逼。

  12. 这个工具有用,我的驱动能在64位win7测试模式下安装,但为什么在win8系统下安装驱动又提示没有数字签名信息,需要强制关闭数字签名才能安装,不通用吗?

  13. 我的win7系统虽然提示已经签名成功,可是我的驱动还是装不上去,之前inf文件被修改过了,在32位系统上是可以用的,但是在64位系统就装不上。不知道什么原因

  14. 请问你是如何检测是否开启测试模式的?我也需要这样的功能。
    我在自己的程序中也需要检测是否开启测试模式的功能。
    能否提供一些代码或者提供一些相关的API函数,谢谢!

  15. 我用张帆《windows驱动开发技术详解》里的第一个NT驱动以及他的加载NT驱动的代码来测试的。在XP下OK。然后在WIN7旗舰版SP1(VM虚拟机里的系统)里用改工具给helloddk.sys(XP下编译的32位SYS)上了数字签名,查看到是有签名不过邮箱和时间戳不可用。工具勾选了TestSigning也重启了。然后net start helloddk还是提示“发生系统错误1275,此驱动程序被阻止加载”

  16. 张老师,您好!我是刚接触Windows的驱动,有一个自编的PCI驱动,有如下情况,烦请您帮我解答:
    1 win7 64位系统,刚开始插上PCI卡时能发现PCI内存控制器,并可以安装上自编的PCI驱动(.inf和.sys文件,64位的,未数字签名),在设备驱动器那里可以看到刚安装的驱动。重启后按F8 ->禁止签名,进入系统后能正常使用。
    2 有时候再开机后在设备驱动器中看不到了安装的那个设备,扫描也没用。后来通过添加过时硬件,在里面找到安装过的那个设备,能添加成功,但重启进入系统时蓝屏。关掉电源再启动又不蓝屏了。这是怎么回事呢?
    3 看到您这篇文章后,按照您说的方法操作,把安装后的那个.sys文件用64signer软件签名后,不掉点重启和掉电开机进入系统时都出现蓝屏。
    您能帮我分析出问题出在哪吗?不胜感激….

  17. 您好, 非常感谢您的工具,但是我使用时候, 提示:

    mirror.sys is failed to be signed, refer to log file.

    我签的就是winddk自带的mirror driver的驱动。

    非常感谢!

  18. 我的电脑可以正常用64Signer,有另外一个问题请教:客户的64位系统会提示一个驱动程序认证没有通过,我的电脑是可以通过的。我想重新签名试一下,64Signer提示已签过了。这种情况有没有好的建议。

  19. 请问这个样子与开机禁用签名有什么区别呢 是其他没签名的驱动没办法加载 还是其他的都可以

  20. 受益于贵地,故反馈个小笔误。
    文章中的 “Bcdedit /set testsiging true” 写错了, testgigning 少写了一个n哈。

  21. 为啥我还是不能安装啊,我运行了你的程序后进入我的那个文件点属性之后发现是有签证了,但是真正在安装过程中还是出现那个签证出错的问题,请问是怎么回事啊,我的软件是Intel 的System studio

  22. 张老师你好:
    我这边是window 10 64 系统,我使用64signer给我的sys文件签名,无论是否Enable Test signing option选项都显示签名成功,但是我用手动选择“更新驱动程序软件”安装我的驱动程序的时候,显示的是:“Window 已找到设备的驱动程序软件,但在试图安装它时遇到错误。第三方INF不包含数字签名信息。”请问这个应该如何解决

  23. 谢谢博主!不知道对该博文是否还有更新。Win10的sign要求更高了,看起来secure boot打开了必须WHQL driver才能工作,这是我实验结果,MSDN上看了多次也没找到哪里明确说这一点。另外就是cross certificate,普通的商业证书比如厂商从verisign等机构购买的证书去sign自己的driver, 但如果不是微软code sign的cross cert是否还得必须开test mode?我用两家的driver做实验,发现没有cross cert的一个不用开test mode,而另外一个必须开test mode, 迷惑了。

  24. 最近看openssl 的code ,博主这个工具是基于开源的工具实现的么?
    很想自己做一个,博主能否告知下实现方法,非常感谢

xiaohe进行回复 取消回复

电子邮件地址不会被公开。