#include <winsvc.h>
#include <conio.h>
#include <stdio.h>
#define DRIVER_NAME "123467"
#define DRIVER_PATH "..\\HelloDDK.sys"
//竖念装载NT驱动程序
BOOL LoadNTDriver(char* lpszDriverName,char* lpszDriverPath)
{
/************************ 加载NT驱动的代码*******************************
① 调用OpenSCManager,打开SCM管理器.如果返回NULL,则返回失败,否则继续
② 调用CreateService,创建服务,创建成功则转步骤 ⑥
③ 用GetLastError的得到错误返回值
④ 返回值为ERROR_IO_PENDING,说明服务已经创建过,用OpenService打开此服务.
⑤ 返回值为其他值, 创建武服务失败,返回失败.
⑥ 调用StartService开启服务
⑦ 成功返回
************************************************************************/
char szDriverImagePath[256]
//得到完整的驱动路径
GetFullPathName(lpszDriverPath, 256, szDriverImagePath, NULL)
BOOL bRet = FALSE
SC_HANDLE hServiceMgr=NULL// SCM管理器的句柄
SC_HANDLE hServiceDDK=NULL// NT驱动程序的服务句柄余判困
//打开服务控制管理器
hServiceMgr = OpenSCManager( NULL, NULL, SC_MANAGER_ALL_ACCESS )
if( hServiceMgr == NULL )
{
// OpenSCManager失败
printf( "OpenSCManager() Faild %d ! \n", GetLastError() )
bRet = FALSE
goto BeforeLeave
}
else
{
// OpenSCManager成功
printf( "OpenSCManager() ok ! \n" )
}
//创建驱动所对应的服务
hServiceDDK = CreateService( hServiceMgr,
lpszDriverName, // 驱动程序的在注册表中的名字
lpszDriverName, // 注册表驱动程序的 DisplayName 值
SERVICE_ALL_ACCESS, // 加载驱动程序的访问权限
SERVICE_KERNEL_DRIVER, // 表示加载的服务是驱动程序
SERVICE_DEMAND_START, /冲慎/ 注册表驱动程序的 Start 值
SERVICE_ERROR_IGNORE, // 注册表驱动程序的 ErrorControl 值
szDriverImagePath, // 注册表驱动程序的 ImagePath 值
NULL,
NULL,
NULL,
NULL,
NULL)
DWORD dwRtn
// 判断服务是否失败
if( hServiceDDK == NULL )
{
dwRtn = GetLastError()
if( dwRtn != ERROR_IO_PENDING &&dwRtn != ERROR_SERVICE_EXISTS )
{
//由于其他原因创建服务失败
printf( "CrateService() Faild %d ! \n", dwRtn )
bRet = FALSE
goto BeforeLeave
}
else
{
//服务创建失败,是由于服务已经创立过
printf( "CrateService() Faild Service is ERROR_IO_PENDING or ERROR_SERVICE_EXISTS! \n" )
}
// 驱动程序已经加载,只需要打开
hServiceDDK = OpenService( hServiceMgr, lpszDriverName, SERVICE_ALL_ACCESS )
if( hServiceDDK == NULL )
{
// 如果打开服务也失败,则意味错误
dwRtn = GetLastError()
printf( "OpenService() Faild %d ! \n", dwRtn )
bRet = FALSE
goto BeforeLeave
}
else
{
printf( "OpenService() ok ! \n" )
}
}
else
{
printf( "CrateService() ok ! \n" )
}
// 开启此项服务
bRet= StartService( hServiceDDK, NULL, NULL )
if( !bRet )
{
DWORD dwRtn = GetLastError()
if( dwRtn != ERROR_IO_PENDING &&dwRtn != ERROR_SERVICE_ALREADY_RUNNING )
{
printf( "StartService() Faild %d ! \n", dwRtn )
bRet = FALSE
goto BeforeLeave
}
else
{
if( dwRtn == ERROR_IO_PENDING )
{
// 设备被挂住
printf( "StartService() Faild ERROR_IO_PENDING ! \n")
bRet = FALSE
goto BeforeLeave
}
else
{
// 服务已经开启
printf( "StartService() Faild ERROR_SERVICE_ALREADY_RUNNING ! \n")
bRet = TRUE
goto BeforeLeave
}
}
}
bRet = TRUE
// 离开前关闭句柄
BeforeLeave:
if(hServiceDDK)
{
CloseServiceHandle(hServiceDDK)// 服务句柄
}
if(hServiceMgr)
{
CloseServiceHandle(hServiceMgr)// SCM句柄
}
return bRet
}
// 卸载驱动程序
BOOL UnloadNTDriver( char * szSvrName )
{
/************************* 卸载NT驱动的代码******************************
① 调用OpenSCManager,打开SCM管理器,如果返回NULL,则返回失败,否则继续.
② 调用OpenService.如果返回NULL,则返回失败,否则继续
③ 调用DeleteService卸载此项服务.
④ 成功返回.
************************************************************************/
BOOL bRet = FALSE
SC_HANDLE hServiceMgr=NULL// SCM管理器的句柄
SC_HANDLE hServiceDDK=NULL// NT驱动程序的服务句柄
SERVICE_STATUS SvrSta
// 打开SCM管理器
hServiceMgr = OpenSCManager( NULL, NULL, SC_MANAGER_ALL_ACCESS )
if( hServiceMgr == NULL )
{
// 打开SCM管理器失败
printf( "OpenSCManager() Faild %d ! \n", GetLastError() )
bRet = FALSE
goto BeforeLeave
}
else
{
// 打开SCM管理器失败成功
printf( "OpenSCManager() ok ! \n" )
}
// 打开驱动所对应的服务
hServiceDDK = OpenService( hServiceMgr, szSvrName, SERVICE_ALL_ACCESS )
if( hServiceDDK == NULL )
{
// 打开驱动所对应的服务失败
printf( "OpenService() Faild %d ! \n", GetLastError() )
bRet = FALSE
goto BeforeLeave
}
else
{
printf( "OpenService() ok ! \n" )
}
// 停止驱动程序,如果停止失败,只有重新启动才能,再动态加载。
if( !ControlService( hServiceDDK, SERVICE_CONTROL_STOP , &SvrSta ) )
{
printf( "ControlService() Faild %d !\n", GetLastError() )
}
else
{
// 打开驱动所对应的失败
printf( "ControlService() ok !\n" )
}
// 动态卸载驱动程序。
if( !DeleteService( hServiceDDK ) )
{
// 卸载失败
printf( "DeleteSrevice() Faild %d !\n", GetLastError() )
}
else
{
// 卸载成功
printf( "DelServer:eleteSrevice() ok !\n" )
}
bRet = TRUE
BeforeLeave:
// 离开前关闭打开的句柄
if(hServiceDDK)
{
CloseServiceHandle(hServiceDDK)// 服务句柄
}
if(hServiceMgr)
{
CloseServiceHandle(hServiceMgr)// SCM 句柄
}
return bRet
}
void TestDriver()
{
// 测试驱动程序
HANDLE hDevice = CreateFile("\\\\.\\HelloDDK",
GENERIC_WRITE | GENERIC_READ,
0,
NULL,
OPEN_EXISTING,
0,
NULL)
if( hDevice != INVALID_HANDLE_VALUE )
{
MessageBox(NULL,"SUCESSFULLY....ComeOn...","Yes",0)
printf( "Create Device ok ! \n" )
}
else
{
printf( "Create Device faild %d ! \n", GetLastError() )
MessageBox(NULL,"Faild...Fuckking...","No",0)
}
CloseHandle( hDevice )
}
int main(int argc, char* argv[])
{
UnloadNTDriver(DRIVER_NAME)
// 加载驱动
BOOL bRet = LoadNTDriver(DRIVER_NAME,DRIVER_PATH)
if (!bRet)
{
printf("LoadNTDriver error\n")
return 0
}
// 加载成功
printf( "press any to create device!\n" )
getch()
TestDriver()
// 这时候你可以通过注册表,或其他查看符号连接的软件验证。
printf( "press any to unload the driver!\n" )
getch()
// 卸载驱动
UnloadNTDriver(DRIVER_NAME)
// if (!bRet)
// {
// printf("UnloadNTDriver error\n")
// return 0
// }
system("pause")
return 0
}
http://hi.baidu.com/xiaoduo170/blog/item/84b4ae137cc3c30a5baf535e.html
SYS是驱动文件后缀,VC是是个集成环境,你要是想VC可以生成SYS文件,就要配置VC的编译环境,这个网上有很多。http://blog.csdn.net/wangcheng711/archive/2007/03/22/1538083.aspx
这个是棚纳一个网上讲解的贺睁如何配置,还禅和岁有很多,你如果不明白,再搜一下。
system函数:int__cdecl system(const char *)
即调用DOS命令,
需要包含的头文件为:<cstdlib>
比如 system("cls")//清屏,等于在DOS上使用cls命令
下面列出常用的DOS命令,都可以用system函数调用:
ASSOC 显示或修改文件扩展名关联。
AT 计划在计算机上运行的命令和程序。
ATTRIB 显示或更改文件属性。
BREAK 设置或清除扩展式 CTRL+C 检查。
CACLS 显示或修改文件的访问控制列表(ACLs)。
CALL 从另一个批处理程序调用这一个。
CD 显示当前目录的名称或将其更改。
CHCP 显示或设置活动代码页数。
CHDIR 显示当前目录的名称或将其更改。
CHKDSK 检查磁盘并显示状态报告。
CHKNTFS 显示或修改启动时间磁盘检查。
CLS 清除屏幕。
CMD 打开另一个 Windows 命令解释程序窗口冲运。
COLOR 设置默认控制台前景和背景颜色。
COMP 比较两个或两套文件的内容。
COMPACT 显示或更改 NTFS 分区上文件的压缩。
CONVERT 将 FAT 卷转换成 NTFS。您不伏键能转换
当前驱动器。
COPY 将至少一个文件复制到另一个位置。
DATE 显示或设置日期。
DEL 删除至少一个文件。
DIR 显示一个目录中的文件和子目录。
DISKCOMP 比较两个软盘的内容。
DISKCOPY 将一个软盘的内容复制到另一个软盘。
DOSKEY 编辑命令行、调用 Windows 命令并创建宏。
ECHO 显示消息,或将命令回显打开或关上。
ENDLOCAL 结束批文件中环境更改的本地化。
ERASE 删除至少一个文件。
EXIT 退出 CMD.EXE 程序(命令解释程序)。
FC 比较两个或两套文件,并显示
不同处。
FIND 在文件中搜索文字字符串。
FINDSTR 在文件中搜索字符串。
FOR 为一套文件中的每个文件运行一个指定的命令
FORMAT 格式化磁盘,以便跟 Windows 使用。
FTYPE 显示或修改用于文件扩展名关联的文件类型。
GOTO 将 Windows 命令解释程序指向批处理程序
中某个标明的行。
GRAFTABL 启用 Windows 来以图像模式显示
扩展字符集。
HELP 提供 Windows 命令的帮助信息。
IF 执行批处理程序中的条件性处理。
LABEL 创建、更改或删除磁盘的卷标。
MD 创建目录。
MKDIR 创建目录。
MODE 配置系统设备。
MORE 一次显示一个结果屏幕。
MOVE 将文件从一个目录移到另一个目录。
PATH 显示或设置可执行文件的搜索路径。
PAUSE 暂停批文件的处理并显示消息。
POPD 还原 PUSHD 保存的当前目录的上一个值。
PRINT 打印文本文件。
PROMPT 更改 Windows 命令提示符。
PUSHD 保存当前目录,然后对其进行更改。
RD 删除目录。
RECOVER 从有问题的磁盘恢复可读信息。
REM 记录批文件或 CONFIG.SYS 中的注释。
REN 重命名文件。
RENAME 重命名文件。
REPLACE 替换文件。
RMDIR 删除目录。
SET 显示、设置或删除 Windows 环境变量。
SETLOCAL 开始批文件中环境更改的本地化。
SHIFT 更换批文件中可替换参数的位置。
SORT 对输入进行分类。
START 启动另一个窗口来运行指定的程序或命令。
SUBST 将路径跟一个驱动器号关联。
TIME 显示或设置系统时间。
TITLE 设置 CMD.EXE 会话的窗口标题。
TREE 以图形模式显示驱动器或路径的目录结构。
TYPE 显示文本文件的内容。
VER 显示 Windows 版本。
VERIFY 告诉 Windows 是否验证文件是缺判巧否已正确
写入磁盘。
VOL 显示磁盘卷标和序列号。
XCOPY 复制文件和目录树。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)