Windows内核安全与驱动开发-程序员宅基地

技术标签: 操作系统  数据结构与算法  驱动开发  

这篇是计算机中Windows Mobile/Symbian类的优质预售推荐《Windows内核安全与驱动开发》。


编辑推荐

本书适合计算机安全软件从业人员、计算机相关专业院校学生以及有一定C语言和操作系统基础知识的编程爱好者阅读。


内容简单介绍

本书的前身是《天书夜读——从汇编语言到Windows内核编程》和《寒江独钓——Windows内核安全编程》。

与Windowsclient安全软件开发相关的驱动程序开发是本书的主题。

书中的程序使用环境从32位到64位。从Windows XP到Windows 8都有涉及,大部分程序不经过改动就可以在Windows 10上执行。同一时候本书也深入浅出地介绍了进行内核安全编程所须要的操作系统、汇编等基础知识。


本书共分三篇,基础篇囊括了驱动开发的基础知识。减少了入门的难度;开发篇介绍了在实际工作中可能遇到的各种开发需求的技术实现,包括:串口的过滤、键盘的过滤、磁盘的虚拟、磁盘的过滤、文件系统的过滤与监控、文件系统透明加密、文件系统微过滤驱动、网络传输层过滤、Windows过滤平台、NDIS协议驱动、NDIS小port驱动、NDIS中间层驱动、IA-32汇编基础、IA-32体系中的内存地址、处理器权限级别切换、IA-32体系结构中的中断和Windows内核挂钩。高级篇包括了汇编语言、操作系统原理、处理器体系架构相关的内容。本书是由长期从事这个行业的project师自己写的,所以处处以有用为准。

对细节的考究主要体如今对实际问题的解决,而不是知识的详尽程度上。 


部分文件夹

基 础 篇

第1章 内核上机指导 2
1.1 下载和使用WDK 2
1.1.1 下载并安装WDK 2
1.1.2 编写第一个C文件 4
1.1.3 编译一个project 5
1.2 安装与执行 6
1.2.1 下载一个安装工具 6
1.2.2 执行与查看输出信息 7
1.2.3 在虚拟机中执行 8
1.3 调试内核模块 9
1.3.1 下载和安装WinDbg 9
1.3.2 设置Windows XP调试运行 9
1.3.3 设置Vista调试运行 10
1.3.4 设置VMware的管道虚拟串口 11
1.3.5 设置Windows内核符号表 12
1.3.6 实战调试first 13
第2章 内核编程环境及其特殊性 16
2.1 内核编程的环境 16

2.1.1 隔离的应用程序 16
2.1.2 共享的内核空间 17
2.1.3 无处不在的内核模块 18
2.2 数据类型 19
2.2.1 基本数据类型 19
2.2.2 返回状态 19
2.2.3 字符串 20
2.3 重要的数据结构 21
2.3.1 驱动对象 21
2.3.2 设备对象 22
2.3.3 请求 24
2.4 函数调用 25
2.4.1 查阅帮助 25
2.4.2 帮助中有的几类函数 26
2.4.3 帮助中没有的函数 28
2.5 Windows的驱动开发模型 29
2.6 WDK编程中的特殊点 30
2.6.1 内核编程的主要调用源 30
2.6.2 函数的多线程安全性 30
2.6.3 代码的中断级 32
2.6.4 WDK中出现的特殊代码 32
第3章 字符串与链表 35
3.1 字符串操作 35
3.1.1 使用字符串结构 35
3.1.2 字符串的初始化 36
3.1.3 字符串的拷贝 37
3.1.4 字符串的连接 38
3.1.5 字符串的打印 38
3.2 内存与链表 40
3.2.1 内存的分配与释放 40
3.2.2 使用LIST_ENTRY 41
3.2.3 使用长长整型数据 43
3.3 自旋锁 44
3.3.1 使用自旋锁 44
3.3.2 在双向链表中使用自旋锁 45
3.3.3 使用队列自旋锁提高性能 46
第4章 文件、注冊表、线程 47
4.1 文件操作 47
4.1.1 使用OBJECT_ATTRIBUTES 47
4.1.2 打开和关闭文件 48
4.1.3 文件读/写操作 51
4.2 注冊表操作 53
4.2.1 注冊表键的打开 53
4.2.2 注冊表键值的读 55
4.2.3 注冊表键值的写 57
4.3 时间与定时器 58
4.3.1 获得当前“滴答”数 58
4.3.2 获得当前系统时间 58
4.3.3 使用定时器 59
4.4 线程与事件 62
4.4.1 使用系统线程 62
4.4.2 在线程中睡眠 63
4.4.3 使用同步事件 64
第5章 应用与内核通信 67
5.1 内核方面的编程 68
5.1.1 生成控制设备 68
5.1.2 控制设备的名字和符号链接 70
5.1.3 控制设备的删除 71
5.1.4 分发函数 72
5.1.5 请求的处理 73
5.2 应用方面的编程 74
5.2.1 主要的功能需求 74
5.2.2 在应用程序中打开与关闭设备 75
5.2.3 设备控制请求 75
5.2.4 内核中的相应处理 77
5.2.5 结合測试的效果 79
5.3 堵塞、等待与安全设计 80
5.3.1 驱动主动通知应用 80
5.3.2 通信接口的測试 81
5.3.3 内核中的缓冲区链表结构 83
5.3.4 输入:内核中的请求处理中的安全检查 84
5.3.5 输出处理与卸载清理 85
第6章 64位和32位内核开发差异 88
6.1 64位系统新增机制 88
6.1.1 WOW64子系统 88
6.1.2 PatchGuard技术 91
6.1.3 64位驱动的编译、安装与执行 91
6.2 编程差异 92
6.2.1 汇编嵌入变化 92
6.2.2 预处理与条件编译 93
6.2.3 数据结构调整 93 
开发篇等等···


窝们站点预售的该本书,购买传送门点击打开链接



版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_33713503/article/details/86430620

智能推荐

mmdetection3d 源码学习 mvxnet(多模态融合)-程序员宅基地

文章浏览阅读5k次。mmdetection3d 源码学习 mvxnet(多模态融合)配置文件dv_mvx-fpn_second_secfpn_adamw_2x8_80e_kitti-3d-3class.py模型# model settingsvoxel_size = [0.05, 0.05, 0.1]point_cloud_range = [0, -40, -3, 70.4, 40, 1]##模型 图像:主干 ResNet,neck FPN;点云:voxel编码,主干second(稀疏编码),neck secon_mvxnet

C++操作Mysql数据库/Linux下_c++ 操作mysql数据库-程序员宅基地

文章浏览阅读3.3k次,点赞14次,收藏36次。想用C++写项目,数据库是必须的,所以这两天学了一下C++操作Mysql数据库的方法。也没有什么教程,就是在网上搜的知识,下面汇总一下。 连接MySQL数据库有两种方法:第一种是使用ADO连接,不过这种只适合Windows平台;第二种是使用MySQL自己的C API函数连接数据库。我是在Linux平台下开发,所以就采用第二种方法,有很多Api函数,但是常用的就几个,我也是就用到其中的几个。API函_c++ 操作mysql数据库

在Watir中调用JavaScript脚本_watir执行脚本-程序员宅基地

文章浏览阅读3.9k次。如何在Watir中调用JavaScript脚本?下面的脚本实现了此功能,主要原理是通过IE访问Document,再访问parentWindow,最终还是由IE在执行JavaScript脚本: require watir#定义调用JS的类方法class Watir::IE def run_script(js) ie.Document.parentWindow.execS_watir执行脚本

为什么不能使用Thread.stop()方法?_禁止使用thread.stop()来终止线程-程序员宅基地

文章浏览阅读2.1k次。从SUN的官方文档可以得知,调用Thread.stop()方法是不安全的,这是因为当调用Thread.stop()方法时,会发生下面两件事:1. 即刻抛出ThreadDeath异常,在线程的run()方法内,任何一点都有可能抛出ThreadDeath Error,包括在catch或finally语句中。2. 释放该线程所持有的所有的锁 当线程抛出ThreadDeath异常时,会导致_禁止使用thread.stop()来终止线程

神秘魔术动作能量冲击波特效音效Arcane Forces第一套 MAGIC - ARCANE FORCES DESIGNED_magic – arcane forces-程序员宅基地

文章浏览阅读222次。神秘魔术动作能量冲击波特效音效Arcane Forces第一套 MAGIC - ARCANE FORCES DESIGNED原文地址:https://www.aeziyuan.com/t-20646.html文件格式:.WAV文件大小:1.26 GB(解压包大小)文件数量:124音频码率:96kHz, 24-bit音效适用于任何音/视频后期编辑软件,直接导入即可使用包含:酸,奥术,障壁,呼吸,增益,诅咒,减伤,神圣,电,能量,火,玻璃,冰,冲击,光,液体,金属,加工,抛射,隆隆声,序,召唤,._magic – arcane forces

commons-io工具包的基本使用_ioutils.tobytearray-程序员宅基地

文章浏览阅读4w次,点赞57次,收藏304次。目录一、工具类IOUtils的使用:FileUtils的使用:FilenameUtils的使用FileSystemUtils的使用:二、输入、输出三、Filters过滤器四、Comparators比较器五、Monitor文件监控简介:java io操作是开发中比较常用的技术,但是如果每次都使用原生的IO流来操作会显得比较繁琐。Common IO 是一..._ioutils.tobytearray

随便推点

CI867AK01丨Modbus TCP接口模件丨3BSE092689R1-程序员宅基地

文章浏览阅读450次,点赞4次,收藏6次。CI867AK013BSE092689R1Modbus TCP接口模件模块,通过无线或有线的方式,实现设备之间的数据传输和通信连接。

PySide2入门--PySide2介绍与配置-程序员宅基地

文章浏览阅读2w次,点赞16次,收藏96次。前言 因为有对GUI界面开发的需求,我前些阵子接触过Qt,一套著名的跨平台的C++图形界面框架。Qt开发最有效的Qt creator,跨平台且集成多款工具,上手体验十分友好。但是,由于C++导入第三方库相对麻烦,而且现有的代码都基于Python实现。此处将介绍Qt相应的Python模块——PySide。为什么不选择PyQt? PySide2和PyQt5同样对应的Qt5框架,PyQt甚至要比PySide出现更早,社区更完备、中文文档更丰富。但是,值得注意的是:二者的许可证存在着差异。 PyQ_pyside2

Jupyter Notebook如何调试?JupyterLab作为DeBug调试工具及调试教程_jupyterlab怎么debug-程序员宅基地

文章浏览阅读2.9w次,点赞30次,收藏107次。引言xeus-python是2020年新出的Jupyter notebook调试工具,参考机器之心的文章首款 Jupyter 官方可视化 Debug 工具,JupyterLab 未来可默认支持 Debug安装过程安装JupyterLab 前端插件jupyter labextension install @jupyterlab/debugger安装xeus-python作为后端kernelconda install xeus-python -c conda-forge调试教程只要装好前端与_jupyterlab怎么debug

如何将xml转换为json_xml转json-程序员宅基地

文章浏览阅读3.8k次。<dependency> <groupId>org.json</groupId> <artifactId>json</artifactId> <version>20160807</version> </dependency>导入 json-20160807.jar jar包 直接调用 XML.toJSONObject(“xml内容”) 就可以把XML._xml转json

TCP 的那些事 | TCP报文格式解析_.tcp文件是图片吗-程序员宅基地

文章浏览阅读1.3k次。TCP(Transmission Control Protocol 传输控制协议)提供一种面向连接的、可靠的字节流服务。面向连接意味着两个使用TCP的应用(通常是一个客户和一个服务器)在彼此交换数据之前必须先建立一个TCP连接。TCP在网络ISO的七层模型中的第四层---Transport层,在TCP/IP协议中的第三层---传输层。TCP通过下列方式来提供可靠性:1. 应用数据被分..._.tcp文件是图片吗

python——stack()和unstack()用法_unstack函数-程序员宅基地

文章浏览阅读1.2w次,点赞12次,收藏54次。在学习python的过程中遇到了这两个函数,讲讲学习的心得_unstack函数

推荐文章

热门文章

相关标签