NT式驱动的安装卸载

 AOpenSCManager

      BCreateService

      C、OpenService

      DStartService

      E、CloseServiceHandle

      F、集成到loadNTDriver函数

 

#include <winsvc.h>

正常加载驱动的步骤如下:

 1、调用OpenSCManager,打开SCM管理器。如果返回NULL,则返回失败,否则继续下一步;

 2、调用CreateService创建服务,如果用GetLastError获取的返回值为ERROR_IO_PENDING,说明服务已经创建过,此时用OpenService打开此服务.

 3、调用StartService开启服务

 

SC_HANDLE OpenSCManager(

 LPCTSTR lpMachineName, // 指向计算机名称,此处为NULL表示指向本机
 

 LPCTSTR lpDatabaseName, // SCM数据库名称,此用为NULL表示使用默认

 DWORD dwDesiredAccess   // 使用权限 一般设置为SC_MANAGER_ALL_ACCESS表示有所有使用权限

);

 

BOOL CloseServiceHandle(
 

SC_HANDLE hSCObject   // 要关闭的SCM句柄

 

 

 

 

 

 

 

    //打开服务控制管理器

    hServiceMgr = OpenSCManager( NULL, NULL, SC_MANAGER_ALL_ACCESS );

 

    //创建驱动所对应的服务

    hServiceDDK = CreateService( hServiceMgr,//SCM管理器句柄

        lpszDriverName, //驱动程序的在注册表中的名字 

        lpszDriverName, // 注册表驱动程序的 DisplayName 值 

        SERVICE_ALL_ACCESS, // 加载驱动程序的访问权限 

        SERVICE_KERNEL_DRIVER,// 表示加载的服务是驱动程序 

        SERVICE_DEMAND_START, // 注册表驱动程序的 Start 值 

        SERVICE_ERROR_IGNORE, // 注册表驱动程序的 ErrorControl 值 

        szDriverImagePath, // 注册表驱动程序的 ImagePath 值 

        NULL,              //要开启服务的 用户组

        NULL,  //输出验证标签

        NULL,   //所依赖的服务的名称

        NULL,   //用户账户名称

        NULL);  //用户口令

 

    // 驱动程序已经加载,只需要打开 

        hServiceDDK = OpenService( hServiceMgr, lpszDriverName, SERVICE_ALL_ACCESS );

   //开启此项服务

    bRet= StartService( hServiceDDK, NULL, NULL );

 

 

 

//装载NT驱动程序

BOOL LoadNTDriver(char* lpDriverName,char* lpDriverPathName)

{

    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失败

        TRACE( "OpenSCManager() Faild %d ! \n", GetLastError() );

        bRet = FALSE;

        goto BExit;

    }

    else

    {

        OpenSCManager成功

        TRACE( "OpenSCManager() ok ! \n" ); 

    }

 

    //创建驱动所对应的服务

    hServiceDDK = CreateService( hServiceMgr,

        lpDriverName, //驱动程序的在注册表中的名字 

        lpDriverName, // 注册表驱动程序的 DisplayName 值 

        SERVICE_ALL_ACCESS, // 加载驱动程序的访问权限 

        SERVICE_KERNEL_DRIVER,// 表示加载的服务是驱动程序 

        SERVICE_DEMAND_START, // 注册表驱动程序的 Start 值 

        SERVICE_ERROR_IGNORE, // 注册表驱动程序的 ErrorControl 值 

        lpDriverPathName, // 注册表驱动程序的 ImagePath 值 

        NULL, 

        NULL, 

        NULL, 

        NULL, 

        NULL); 

 

    DWORD dwRtn;

    //判断服务是否失败

    if( hServiceDDK == NULL ) 

    { 

        dwRtn = GetLastError();

        if( dwRtn != ERROR_IO_PENDING && dwRtn != ERROR_SERVICE_EXISTS ) 

        { 

            //由于其他原因创建服务失败

            TRACE( "CrateService() 失败 %d ! \n", dwRtn ); 

            bRet = FALSE;

            goto BExit;

        } 

        else 

        {

            //服务创建失败,是由于服务已经创立过

            TRACE( "CrateService() 服务创建失败,是由于服务已经创立过 ERROR is ERROR_IO_PENDING or ERROR_SERVICE_EXISTS! \n" ); 

        }

 

        // 驱动程序已经加载,只需要打开 

        hServiceDDK = OpenService( hServiceMgr, lpDriverName, SERVICE_ALL_ACCESS ); 

        if( hServiceDDK == NULL ) 

        {

            //如果打开服务也失败,则意味错误

            dwRtn = GetLastError(); 

            TRACE( "OpenService() 失败 %d ! \n", dwRtn ); 

            bRet = FALSE;

            goto BExit;

        } 

        else

        {

            TRACE( "OpenService() 成功 ! \n" );

        }

    } 

    else 

    {

        TRACE( "CrateService() 成功 ! \n" );

    }

 

    //开启此项服务

    bRet= StartService( hServiceDDK, NULL, NULL ); 

    if( !bRet )  //开启服务不成功

    { 

            TRACE( "StartService() 失败 服务可能已经开启%d ! \n", dwRtn ); 

    }

    bRet = TRUE;

//离开前关闭句柄

BExit:

    if(hServiceDDK)

    {

        CloseServiceHandle(hServiceDDK);

    }

    if(hServiceMgr)

    {

        CloseServiceHandle(hServiceMgr);

    }

    return bRet;

}

 

、、、、、、、、、、、、、、、、、、、、、、、、、、、、

 A、卸载驱动流程

   B、内核函数DeleteService

   C、内核函数ControlService

   D、构建UnLoadSys函数

   E、测试并查看调试信息

 

 

   一、卸载驱动流程     

 1、用OpenSCManager函数打开 服务控制管理器,取得SCM句柄,如果返回NULL,则结束,否则继续2.//hSCM

 2、用OpenService打开相应的服务,如果返回NULL,则结束,否则继续3.hSerVice

 3、用ControlService停止驱动服务,如果返回NULL,只有重新启动才能,再动态加载。

 4、用DeleteService动态卸载驱动程序,如果返回NULL,则打印出错调试信息,否则打印成功信息。

 

//卸载驱动程序 

BOOL UnLoadSys( char * szSvrName ) 

{

//一定义所用到的变量

    BOOL bRet = FALSE;

    SC_HANDLE hSCM=NULL;//SCM管理器的句柄,用来存放OpenSCManager的返回值

    SC_HANDLE hService=NULL;//NT驱动程序的服务句柄,用来存放OpenService的返回值

    SERVICE_STATUS SvrSta;

//二打开SCM管理器

    hSCM = OpenSCManager( NULL, NULL, SC_MANAGER_ALL_ACCESS ); 

    if( hSCM == NULL ) 

    {

        //带开SCM管理器失败

        TRACE( "OpenSCManager() Faild %d ! \n", GetLastError() ); 

        bRet = FALSE;

        goto BeforeLeave;

    } 

    else 

    {

        //打开SCM管理器成功

        TRACE( "OpenSCManager() ok ! \n" ); 

    }

//三打开驱动所对应的服务

    hService = OpenService( hSCM, szSvrName, SERVICE_ALL_ACCESS ); 

   

    if( hService == NULL ) 

    {

        //打开驱动所对应的服务失败 退出

        TRACE( "OpenService() Faild %d ! \n", GetLastError() ); 

        bRet = FALSE;

        goto BeforeLeave;

    } 

    else 

    { 

        TRACE( "OpenService() ok ! \n" );  //打开驱动所对应的服务 成功

    } 

//四停止驱动程序,如果停止失败,只有重新启动才能,再动态加载。 

    if( !ControlService( hService, SERVICE_CONTROL_STOP , &SvrSta ) ) 

    { 

        TRACE( "用ControlService() 停止驱动程序失败 错误号:%d !\n", GetLastError() ); 

    } 

    else 

    {

        //停止驱动程序成功

        TRACE( "用ControlService() 停止驱动程序成功 !\n" ); 

    } 

//五动态卸载驱动服务。 

    if( !DeleteService( hService ) )  //TRUE//FALSE

    {

        //卸载失败

        TRACE( "卸载失败:DeleteSrevice()错误号:%d !\n", GetLastError() ); 

    } 

    else 

    { 

        //卸载成功

        TRACE ( "卸载成功 !\n" ); 

         

    } 

    bRet = TRUE;

//六 离开前关闭打开的句柄

BeforeLeave:

    if(hService>0)

    {

        CloseServiceHandle(hService);

    }

    if(hSCM>0)

    {

        CloseServiceHandle(hSCM);

    }

    return bRet;   

}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小蚂蚁_CrkRes

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值