NT式驱动加载器

本文详细介绍了如何在Windows系统中通过NT式驱动加载器进行驱动的安装、启动、停止和卸载。主要涉及OpenSCManager、CreateService、StartService、ControlService和DeleteService等关键API的使用,实现对驱动服务的全面操作。

引言


设备驱动程序的动态加载主要是由服务控制管理程序(Service Control Manager,SCM)系统组件完成,SCM组件可以提供许多服务,如,启动、停止和控制服务。
编写加载驱动程序,主要是操作SCM组件。
一般,操作SCM组件的相关API函数有如下几个:
SC_HANDLE WINAPI OpenSCManager(
  __in_opt  LPCTSTR lpMachineName,//计算机名称
  __in_opt  LPCTSTR lpDatabaseName,//SCM数据库名称
  __in      DWORD dwDesiredAccess//使用权限
);

BOOL WINAPI CloseServiceHandle(
  __in  SC_HANDLE hSCObject //要关闭的SCM句柄
);

SC_HANDLE WINAPI CreateService(
  __in       SC_HANDLE hSCManager, //SCM管理器的句柄
  __in       LPCTSTR lpServiceName, //服务名称
  __in_opt   LPCTSTR lpDisplayName, //服务显示出的名称
  __in       DWORD dwDesiredAccess, //打开权限
  __in       DWORD dwServiceType, //服务类型
  __in       DWORD dwStartType, //打开服务的时间
  __in       DWORD dwErrorControl, //关于错误处理的代码
  __in_opt   LPCTSTR lpBinaryPathName, //二进制文件的代码
  __in_opt   LPCTSTR lpLoadOrderGroup, //用什么用户组开发服务
  __out_opt  LPDWORD lpdwTagId, //输出验证标签
  __in_opt   LPCTSTR lpDependencies, //所依赖的服务名称
  __in_opt   LPCTSTR lpServiceStartName,//用户账户名称
  __in_opt   LPCTSTR lpPassword //用户口令
);

SC_HANDLE WINAPI OpenService(
  __in  SC_HANDLE hSCManager, //SCM数据库的句柄
  __in  LPCTSTR lpServiceName, //服务名称
  __in  DWORD dwDesiredAccess //访问权限
);

BOOL WINAPI ControlService(
  __in   SC_HANDLE hService, //服务的句柄
  __in   DWORD dwControl, //控制码
  __out  LPSERVICE_STATUS lpServiceStatus//返回状态码
); 

文件拖拽

要使对话框支持文件拖拽功能,只需3步即可实现
1> 对话框模版的 Accept Files 属性设置成 True
2> 响应主对话框类的 WM_DROPFILES 消息

3> 添加如下示例代码:

	TCHAR szPath[MAX_
源码免费下载链接】:https://renmaiwang.cn/s/8okgv 软件开发项目"驱动加载工具(附源码)"旨在模仿知名驱动加载工具InstDvr的架构进行优化设计。该功能模块的主要作用是辅助开发者在编写驱动程序时更加便捷地完成程序加载与调试任务。基于Win API SDK(Windows应用程序接口软件开发工具包)和C语言实现,该工具通过编译好的可执行文件直接插入系统内存空间来达到驱动加载的目的。 采用C语言进行编程的原因在于其对底层系统的强大交互能力,特别适合编写驱动程序。开发环境选用Visual C++ 6.0这一经典的微软IDE,虽然已逐渐被淘汰,但因其在相关教程和学习资源中仍被广泛使用,因此适合作为初学者实践开发的平台。 本压缩包中的源代码包含完整的项目文件结构,涵盖头文件、源码文件等。具体包括: 1. LoadSys.aps:Visual C++ 6.0工程预编译头文件。 2. LoadSys.c:C语言实现驱动加载逻辑的核心代码文件。 3. LoadSys.dsp和LoadSys.dsw:相关项目配置信息的IDE工作区文件。 4. resource.h:定义系统资源标识符的头文件,包含菜单、对话框等对象描述。 5. LoadSys.ico:程序图标文件。 6. LoadSys.opt:项目编译选项设置文件。 7. LoadSys.rc:非代码资源脚本文件,定义字符串、菜单等内容。 8. 说明.txt:工具使用说明文档。 9. Release:编译完成后生成的可执行文件目录。 通过解析这些相关组件,开发者可以深入了解驱动加载工具的构建与运行流程。源码的开放性特征使其具备高度灵活性,用户可根据实际需求对功能进行调整和扩展,从而获得更加贴合自身开发需求的应用工具。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值