当前位置: 首页 > news >正文

配置Windows内核开发环境

前言

以前在书上看到,说现在的安全软件已经将对抗转移到内核层了,深以为然。

因为像360安全卫士,腾讯电脑管家这样的安全软件,仅通过用户层api很难做到更高级的防御和控制。

早些年我想获取电脑硬盘的详细使用信息,像鲁大师那样,但是一番找寻下来,并未在网上搜到满意的答案,自己所学也有限,后面索性就放弃了。

最近在github上看到一款项目,实现了跟跟鲁大师类似的磁盘信息读取功能。

我没有详细去看实现的代码,据我的一位不熟悉的朋友说,这里的实现是基于内核层的。

像在鲁大师的安装目录下,可以看到很多.sys的文件,这就说明鲁大师的很多功能,也是通过内核层代码实现的。

我其实一直是做桌面开发的,以C#为主,目前的水平和年纪,混口饭吃还行。学习内核开发,主要也是出于兴趣,也不说要学到什么程度,看心情吧。

值得注意的是,内核开发,并不仅仅只为了驱动某个硬件,也可以单纯的是为了实现某种功能。就像上面鲁大师里的那些.sys文件。

下载Visual Studio 2022

下载地址:https://visualstudio.microsoft.com/zh-hans/downloads/

下图指明了不同版本的 WDK 需要的 Visual Studio 版本,我这里选择的是Visual Studio 2022

安装Windows SDK

在Visual Studio 2022的工作负载中进行钩选对应 的Windows SDK(注意:版本号需要和后面安装的WDK对应)

安装WDK(Windows Driver Kit)

下载地址:

https://learn.microsoft.com/zh-cn/windows-hardware/drivers/download-the-wdk#download-icon-step-3-install-wdk

下载执行安装,安装完成后会安装Visual Studio 2022的WDK扩展

 安装完成后,可以在Visual Studio 新建工程的模板中看到Driver这个类别

选择KMDF工程创建,编译通过,至此,开发环境就安装完成了

额外准备的

1、准备除开发环境外的另外一台电脑,后续调试时会用到,最好使用虚拟机来进行调试。

2、sysinternals工具包,下载地址 Sysinternals 实用工具 - Sysinternals | Microsoft Learn

参考资料:

下载 Windows 驱动程序工具包

下载 Windows 驱动程序工具包 (WDK) - Windows drivers | Microsoft Learn

《Windows Kernel Programming, Second Edition》 Pavel Yosifovich

《Windows内核编程》([美]帕维尔·约西福维奇(Pavel,Yosifovich))【摘要 书评 试读】- 京东图书

《Windows内核编程》 谭文、陈铭霖

《Windows内核编程》(谭文)【摘要 书评 试读】- 京东图书

http://www.lryc.cn/news/440780.html

相关文章:

  • nanoGPT用红楼梦数据从头训练babyGPT-12.32M实现任意问答
  • PDF转图片的思路思考
  • lnmp - 登录技术方案设计与实现
  • 如何在 Qt 的 QListWidget 中逐行添加和显示数据
  • Java API 之集合框架进阶
  • Java String isEmpty()方法
  • Redisson分布式锁分析,可重入、可续锁(看门狗)
  • C++掉血迷宫
  • Spring Boot- 数据库相关问题
  • 秒懂C++之特殊类设计
  • 人工智能学习
  • WINDOWS AGENTARENA:EVALUATING MULTI-MODAL OS AGENTS AT SCALE论文学习
  • 3步轻松定制报价方案,亿发商城报价神器你用过了吗?
  • CISP备考题库(五)
  • 【Kubernetes】常见面试题汇总(二十三)
  • linux-Shell 编程-Shell 脚本基础
  • Linux运维篇-tigervnc工具的使用
  • 基于Spark的电影推荐系统设计与实现(论文+源码)_kaic
  • 基于python+django+vue的医院预约挂号系统
  • 镀金引线---
  • 『功能项目』窗口可拖拽脚本【59】
  • Map--08--CurrentHashMap 与 Hashtable的异同?
  • Docker学习笔记(三)存储与卷
  • 硬件工程师笔试面试——滤波器
  • 【SpringBoot3】面向切面 AspectJ AOP 使用详解
  • wav怎么转mp3格式?给你推荐几种音频格式转换方法
  • Redis的AOF持久化、重写机制、RDB持久化、混合持久化
  • Dom4j使用xpath查询xml文
  • 国家专精特新小巨人企业指标解析与扶持领域
  • 进程的属性