勘误说明

由于个人技术水平有限,书中内容错漏在所难免。各位读者在阅读本书的过程中,若发现与自己见解不同之处,一定要坚持自己的意见,并用实践去检验。经过实践检验之后,若发现书中内容仍存在问题,请可以直接在下方直接留言反馈。

对于留言反馈的读者,本站一律予以积分奖励;同时勘误的读者,也会出现在第二版的感谢名单中。

请大家批评指正,不吝赐教

书中演示的开发环境软件下载

用户篇

本书所有的程序开发均是在VS2013上开发完成的,在正式介绍VS2013开发环境安装之前,需要到官网上下载安装文件镜像以及多字节MFC库安装文件。

vs2013.5_ult_chs.iso下载链接:

http://download.microsoft.com/download/9/3/E/93EA27FF-DB02-4822-8771-DCA0238957E9/vs2013.5_ult_chs.iso?type=ISO

vc_mbcsmfc.exe下载链接:

http://www.microsoft.com/zh-cn/download/details.aspx?id=40770

上述两个安装文件下载完毕之后,就可以进行安装了,本文演示使用的操作系统是 64 位 Windows 10。安装完上述两个软件,即可进行第一部分 “用户篇” 内容的学习和练习。

内核篇

VS2013 要进行驱动开发,必须要在上述“用户篇”环境基础上,再下载安装 WDK8.1,可以到微软驱动开发官网上进行下载:

https://developer.microsoft.com/en-us/windows/hardware/windows-driver-kit

注意,下载的 WDK 一定要对应自己的 VS 版本,VS2013 就下载 WDK8.1。

安装步骤,可以参考《Windows黑客编程技术详解》书中内容

本书配套源码下载

https://www.write-bug.com/article/1811.html

勘误收集

下面列举图书目前收集到的错误内容(按目录顺序排列),请读者谨慎阅读:

再次对书中出现上述错误内容而抱歉

上传的附件 cloud_download NTFS_FileLocation_Test_修改.7z ( 155.15kb, 51次下载 ) cloud_download CryptoApi_Rsa_Test_修改.7z ( 156.17kb, 23次下载 ) cloud_download ScreenCapture_Test_修改.7z ( 164.45kb, 33次下载 )
你的回答被采纳后将获得: 100点积分 (将会扣除手续费1点积分。)

keyboard_arrow_left上一篇 : 邱丑丑帅不帅 JSP、JAVA EE、JAVA WEB这3个到底说的是不是一个东西吗??? : 下一篇keyboard_arrow_right

5个回答

Barefoot
2018-12-31 18:08:23

书中 389 页,明明给的是 classifyFn 函数的代码,却在文中写的是 “notifyFn函数的实现代码” !!!

demon-x
2019-01-03 11:20:31

书中内核篇 “18.2 过PatchGuard的进程隐藏” 这一章节介绍的技术,使用 MiProcessLoaderEntry 函数断链的方式,经过跑代码实践验证,该蓝屏的还是会蓝屏,错误代码是0x109,所以并没有过PG!!!

看雪上有大佬已经指出来了,我只是帮忙搬运到这里勘误!!!

https://bbs.pediy.com/thread-248775.htm

dlyfive
2020-09-12 08:43:22

1 混积分

pxc
2021-01-22 21:51:13

您好,反监控的对象回调句柄定位和Minifilter回调在Win7 64下测试没有通过,调用ObUnRegisterCallbacks时蓝屏了。
很感谢您能整理出版这本书,受益匪浅

nagato
2021-02-20 11:02:49

该蓝屏的还是会蓝屏,错误代码是0x109,所以并没有过PG!!!

精彩评论

  • 自学Python语言,是看书好还是看视频好呢?
    视频和书两者结合 先看书在看视频
    2021-02-28 20:11:45 thumb_up( 1 )
  • [算法问题] 谁逃课了
    给你个借鉴吧 我这边是php语言的基本语法如下:直接一个类实现 /** * 1)如果A逃课,B也一定逃课 * 2)B和C中有且只有一个人参与逃课 * 3)C和D要么都逃,要么都不逃 * 4)D和E至少有一个人逃了 * 5)如果E逃课,则A和D一定参与逃课 */class Truancy{ private $first = 'A'; public $set_list = []; public function __construct($first = ''){ if($first) $this->first = $first; array_push($this->set_list , $this->first); $this->relationship(); } // 主要逻辑 private function relationship(){ if(in_array('A',$this->set_list)){ array_push($this->set_list , 'B'); } if(in_array('B',$this->set_list)){ if(in_array('A',$this->set_list) == false){ array_push($this->set_list , 'A'); } if(in_array('C',$this->set_list)){ $key = array_search('C'); unset($this->set_list[$key]); } } if(in_array('C',$this->set_list)){ if(in_array('B',$this->set_list)){ $key = array_search('B'); unset($this->set_list[$key]); } if(in_array('D',$this->set_list) == false){ array_push($this->set_list , 'D'); } } if(in_array('D',$this->set_list) == false){ if(in_array('E',$this->set_list) == false){ $key = rand(1,2); $array_de = ['D','E']; // 两个随机出一个 如果两个都没有逃课的情况任意选择一个 array_push($this->set_list , $array_de[$key-1]); } } if(in_array('E',$this->set_list)){ if(in_array('D',$this->set_list) == false){ array_push($this->set_list , 'D'); } if(in_array('A',$this->set_list) == false){ array_push($this->set_list , 'A'); array_push($this->set_list , 'B'); if(in_array('C',$this->set_list)){ $key = array_search('C'); unset($this->set_list[$key]); $key = array_search('D'); unset($this->set_list[$key]); } } } // 将结果变成字符串显示(数组集合变成字符串) function merge_arr($v1,$v2) { return $v1 . "" . $v2; } sort($this->set_list); $this->set_list = array_reduce($this->set_list,merge_arr); }}$Truancy = new Truancy("B");// 输出结果var_dump($Truancy->set_list) ;
    2021-01-20 09:35:09 thumb_up( 1 )
  • 自学Python语言,是看书好还是看视频好呢?
    跟着视频多写代码比较好
    2021-02-23 15:46:03 thumb_up( 1 )
  • 自学Python语言,是看书好还是看视频好呢?
    推荐看书,python学习手册和python cookbook
    2021-02-22 11:50:12 thumb_up( 1 )
  • 自学Python语言,是看书好还是看视频好呢?
    个人觉得看视频好点,更容易理解。
    2021-02-22 09:54:06 thumb_up( 1 )
  • 说说最近的感想吧(最佳答案不止一个)
    写论文到头秃,计算机学生英语和写作能力也很重要
    2020-06-03 12:22:20 thumb_up( 4 )
  • 说说最近的感想吧(最佳答案不止一个)
    业余时间学学数据结构及算法。。。还有数据库。最好弄个游戏类的软件代码改一改,玩一玩,学一学。
    2020-08-21 10:16:58 thumb_up( 2 )
  • python的web框架
    重量级:Django 轻量级:flask
    2021-02-02 12:12:43 thumb_up( 1 )
  • [算法问题] 谁逃课了
    我也看了这个问题,可能是因为输出格式问题没有ac吧……我用了C语言的位运算,用单个数字表示五个人的逃课状况,比如00000就是都没逃课,01100就是只有BC逃课。用到了位进制运算符>>和<<,在递归函数中用了swich,最大数字是32,用char也可以,占用空间会小一些。 我的代码长这样: include<stdio.h>include<stdlib.h>/A->B; BvC; (C^D)v(-C^-D); DvE; E->(A^D)/ int check(int ans) { if ((ans >> 4) && (ans >> 3) % 2 == 0) return 0; if ((((ans >> 3) % 2) && ((ans >> 2) % 2)) || (!((ans >> 3) % 2) && !((ans >> 2) % 2))) return 0; if (((ans >> 2) % 2) - ((ans >> 1) % 2)) return 0; if (!((ans >> 1) % 2) && !(ans % 2)) return 0; if ((ans % 2) && (!(ans >> 4) || !(ans >> 1) % 2)) return 0; return 1;} int ans(int i, int now) { int a; switch (i) { case 1:{ a = ans(2, 0); if(a) return a; else return ans(2, 1); break; } case 2:{ a = ans(3, (now << 1)); if(a) return a; else return ans(3, (now << 1) + 1); break; } case 3:{ a = ans(4, now << 2); if(a) return a; else return ans(4, (now << 1) + 1); break; } case 4:{ a = ans(5, now << 2); if(a) return a; else return ans(5, (now << 1) + 1); break; } case 5:{ now = (now << 1); if (check(now)) return now; else if (check(++now)) return now; else return 0; break; } default: break; }} int main () { int Ans; Ans = ans(1, 0); if (Ans >> 4) printf(“A”); if ((Ans >> 3) % 2) printf(“B”); if ((Ans >> 2) % 2) printf(“C”); if ((Ans >> 1) % 2) printf(“D”); if ((Ans >> 0) % 2) printf(“E”); printf(“\n”); return 0;}
    2021-03-03 11:53:43 thumb_up( 1 )
  • 你购买"WRITE-BUG技术共享平台"推出的永久VIP了吗
    今天看了Demon-Gan那篇“恶魔成长记”,一篇近万字的文章读下来,我被深深地感动了。真的,我一个男生看的我眼泪都要留下来了。里面的文字不禁让我一次又一次地反思自己,我也是一个大学生啊,我也曾比鸡起得早比狗睡的晚,我也曾昏天黑地用功读书为了梦想挤破脑袋闯过高考大军,然而,我这大学三年多过去了,我都干了些什么,真的是两手空空一无所有。今天是2018年11月12日,距离考研不到40十天了,我还在为着老师布置的程序设计而发愁,出来混迟早要还的真的一点不假,为了那些浪费的时间翘过的课,迟早会会恨到骨子里去的。在最后的这40天里,我希望我能考上,我当然希望我能考上即使不是什么好学校,我希望我还有机会,我希望我还能有一次机会,重新开始。下一次,我当然知道我应该怎么做了,我已经做错那么多了,就想小猪佩奇常常教训自己的弟弟乔治那样“silly George,you do it all wrong!”,今后我一定踏实做人踏实做事。时间线转回主题,今天我看见了Gan在“恶魔的世界群”里发了这个网站,我注册了充了100年的会员,我希望这个网站会越来越好,始终有一群珍爱她的小伙伴,一路上我们一起成长100年,100年对我来说就是永远了吧,100年该有多长啊,我甚至都不知道两年以后是什么样子了。。。。这座城市留下了你的青春,却留不下你。希望这座城市留下了我的青春也能留下我!
    2018-11-12 20:26:07 thumb_up( 24 )
eject