2023驱动保护学习 -- 创建驱动设备及符号链接并实现删除操作

简介: 2023驱动保护学习 -- 创建驱动设备及符号链接并实现删除操作

一、新建一个C文件进行设备添加删除操作

1、创建设备操作,通过状态判断是否创建成功,创建的设备名称只能在内核中使用,如果要在外部应用使用,需要通过符号链接使用,所以需要创建符号链接

NTSTATUS 创建设备(PDRIVER_OBJECT 驱动对象)
{
  NTSTATUS 状态码;
  UNICODE_STRING 驱动名称aiyou;
  PDEVICE_OBJECT 设备对象bucuo;
  RtlInitUnicodeString(&驱动名称aiyou, L"\\DEVICE\\aiyou");//初始化设备名称
  //通过驱动对象创建驱动设备,返回最后的参数设备指针
  状态码 = IoCreateDevice(驱动对象, sizeof(驱动对象->DriverExtension), &驱动名称aiyou, FILE_DEVICE_UNKNOWN, FILE_DEVICE_SECURE_OPEN, FALSE, &设备对象bucuo);
  if (状态码 == STATUS_SUCCESS)
  {
    KdPrint(("nxyn:驱动设备对象创建成功!!! \n"));
    //创建符号链接
    UNICODE_STRING 符号链接名字;  //在应用层使用的名字
    RtlInitUnicodeString(&符号链接名字, L"\\??\\bucuo"); //初始化符号链接名字
    状态码 = IoCreateSymbolicLink(&符号链接名字, &驱动名称aiyou);
    if (状态码 == STATUS_SUCCESS)
    {
      KdPrint(("nxyn:创建符号链接 %wZ 成功!!!", &符号链接名字));
    }
    else
    {
      KdPrint(("nxyn:创建符号链接 %wZ 失败 status=%X!!!", &符号链接名字, 状态码));
    }
  }
  else
  {
    KdPrint(("nxyn:驱动设备对象创建失败,删除设备!!!\n"));
    IoDeleteDevice(设备对象bucuo);
  }
  return 状态码;
}

2、删除设备操作,先删除符号链接,再删除设备,最后再删除驱动

void 删除设备(PDRIVER_OBJECT 驱动对象)
{
  KdPrint(("nxyn:正在删除设备"));
  if (驱动对象->DeviceObject)//是否创建的驱动设备
  {
    UNICODE_STRING 符号链接名字; //符号链接名字     
    RtlInitUnicodeString(&符号链接名字, L"\\??\\bucuo"); 
    KdPrint(("nxyn:删除符号链接=%wZ", &符号链接名字));
    IoDeleteSymbolicLink(&符号链接名字);
    KdPrint(("nxyn:删除驱动设备"));
    IoDeleteDevice(驱动对象->DeviceObject);//删除设备对象
  }
  KdPrint(("nxyn:已全部删除"));
}

二、在上节课的C代码中,声明一下创建设备和删除设备函数

NTSTATUS 创建设备(PDRIVER_OBJECT 驱动对象);
void 删除设备(PDRIVER_OBJECT 驱动对象);

三、在卸载回调函数中调用删除设备,在主函数中调用创建设备

void 卸载驱动回调函数(PDRIVER_OBJECT 驱动对象)
{
  删除设备(驱动对象);
  KdPrint(("nxyn:我被卸载了,驱动编号=%p", 驱动对象));
}
NTSTATUS DriverEntry(_In_ PDRIVER_OBJECT 驱动对象, _In_ PUNICODE_STRING psg)
{
  创建设备(驱动对象);
  驱动对象->DriverUnload = 卸载驱动回调函数;
  KdPrint(("nxyn:第一个驱动程序,驱动编号:%p", 驱动对象));
  return 0;
}

四、运行效果

目录
相关文章
|
SQL Java 关系型数据库
springboot搭建后台框架 (一)整合tkMapper
springboot搭建后台框架 (一)整合tkMapper
185 0
|
存储 数据库 索引
Flutter笔记:滚动之-无限滚动与动态加载的实现(GetX简单状态管理版)
本文介绍Flutter中如何实无线滚动(基于GetX简单状态管理而非有状态组件)
336 0
|
弹性计算 数据可视化 关系型数据库
阿里云服务器部署Java Web项目和连接MySQL数据库全流程
阿里云服务器部署Java Web项目和连接MySQL数据库全流程
6786 0
阿里云服务器部署Java Web项目和连接MySQL数据库全流程
|
云安全 监控 安全
云安全中心和防火墙有什么不同
云安全中心和防火墙有什么不同
661 4
|
存储 安全 大数据
惊呆了、老铁。CSDN竟然有GitHub的加速功能????
这篇文章介绍了几种加速访问GitHub的方法,包括使用镜像网站、代理网站下载、利用CDN加速以及转入Gitee平台进行加速。作者建议,对于较大的项目推荐使用代理网站或Gitee下载,而对于较小的项目,使用CDN加速即可满足需求。
惊呆了、老铁。CSDN竟然有GitHub的加速功能????
|
算法 Linux
深入理解Linux虚拟内存管理(五)(下)
深入理解Linux虚拟内存管理(五)
428 0
|
算法 物联网 Serverless
一键打造你的定制化AIGC文生图工具
【8月更文挑战第2天】一键打造你的定制化AIGC文生图工具
579 0
|
前端开发
【Web 前端】对于数组去重都有哪些方法?
【4月更文挑战第22天】【Web 前端】对于数组去重都有哪些方法?
|
图形学
unity之Layout Group居中显示
unity实现Layout Group居中显示
unity之Layout Group居中显示