修windows服务程序

2012-11-02 08:54 (分类:计算机程序)

     
windows服务是一个周转于后台并促成无需用户交互的职责之控制台程序,对于藏程序来充分非常帮扶。

      用了几龙时间连了编制windows服务程序的轮廓,下面用伪码记录转。

      

//两只全局变量
SERVICE_STATUS_HANDLE StatusHandle
SERVICE_STATUS m_ServiceStatus

void main()

//一个顺序可能含有几单服务。每一个劳动都得列于专门的摊派表中
SERVICE_TABLE_ENTRY ServiceTable[2]; //结构类型的高频组,
ServiceTable[0].lpServiceName = “MemoryStatus”; //服务名
ServiceTable[0].lpServiceProc =
(LPSERVICE_MAIN_FUNCTION)ServiceMain; //服务主函数  
ServiceTable[1].lpServiceName = NULL;
//数组最后一个分子组默认都为NULL
ServiceTable[1].lpServiceProc = NULL;    

// 启动服务的控制分派机线程,
负责把程序主线程连接到服务控制管理程序SCM,通知服务控制次//服务正在实行,并提供函数地址;为各级一个传递及它们的数组中之非空元素产生一个新的线程,每一样//个经过开始推行由数组元素中之指明的ServiceMain函数;SCM启动一个服务程序之后,它会等该/*次第的主线程去调StartServiceCtrlDispatcher。如果那个函数在个别分钟内无受调用,SCM将见面看这个服务来问题,并调用TerminateProcess去杀死之过程。这就是要求您的主线程要尽可能快之调用StartServiceCtrlDispatcher,开始启动服务解析*/

StartServiceCtrlDispatcher(ServiceTable); 

}

ServiceMain 函数
欠函数是劳动之入口点。它运行于一个独立的线程当中,这个线程是由于控制分派器创建的。ServiceMain
应该尽可能早为服务登记控制电脑

void WINAPI ServiceMain()
{
//指定服务特色以及夫眼前状态来初始化 ServiceStatus 结构
m_ServiceStatus.dwServiceType=SERVICE_WIN32_OWN_PROCESS;
//指示服务类型,创建 Win32 服务。赋值 SERVICE_WIN32;
m_ServiceStatus.dwCurrentState=SERVICE_START_PENDING;
//指定服务之即状态。因为劳动之初始化在此间没有做到,所以这里
状态吧SERVICE_START_PENDING;
m_ServiceStatus.dwControlsAccepted=SERVICE_ACCEPT_STOP|SERVICE_ACCEPT_SHUTDOWN
//这个域通知 SCM 服务承受哪个域,停止,关机停止

m_ServiceStatus.dwWin32ExitCode=0; //是同意服务报告错误的关键
m_ServiceStatus.dwServiceSpecificExitCode=0; //一般不关心,设为0

m_ServiceStatus.dwCheckPoint=0;
//是一个劳务用来报其时之事件进行情况的
m_ServiceStatus.dwWaitHint=0; //一般不关心,设为0

//使用API函数RegisterServiceCtrlHandler()设置服务控制管理器SCM的服务控制处理函数
//ServiceMain
应该尽量早为服务注册控制电脑(尽量1秒内)。这只要经调用
//RegisterServiceCtrlHadler
函数来落实;调用RegisterServiceCtrlHandler函数去通知SCM
//它的CtrlHandler回调函数的地址
//SERVICE_STATUS_HANDLE StatusHandle是一个全局变量,当得转移状态时
//SetServiceStatus()用它来标识一个劳务。

SERVICE_STATUS_HANDLE StatusHandle
StatusHandle =RegisterServiceCtrlHadler(“system”,serviceCtrlHandler)
//函数名称 //控制函数CtrlHandler函数地址

//RegisterServiceCtrlHandler返回一个SERVICE_STATUS_HANDLE,这是一个32各类之句柄。SCM用
//它来唯一确定这服务。当这服务要把其就之状态报告给SCM的当儿,就非得把这个词柄传//给得其的Win32函数

//在RegisterServiceCtrlHandler函数返回后,ServiceMain线程要及时告诉SCM服务在继续初始//化。具体的法是由此调用SetServiceStatus函数传递SERVICE_STATUS数据结构。
//通过调用 SetServiceStatus 函数,用 hStatus 向 SCM 报告服务的状态。

//一旦服务被完全初始化,就相应再初始化SERVICE_STATUS结构的分子,更改dwCurrentState
//为SERVICE_RUNNING,然后拿dwCheckPoint和dwWaitHint都改成吧0,将状态就通知被服务控制管
//理器SCM,使用一个API函数SetServiceStatus()来促成这等同对象

m_ServiceStatus.dwCurrentState=SERVICE_START_RUNNING;
m_ServiceStatus.dwCheckPoint=0;
m_ServiceStatus.dwWaitHint=0;

SetServiceStatus(StatusHandle,m_ServiceStatus )
//服务的语句柄 //SERVICE_STATUS结构的地点

door();启动后门程序
return;

}

void WINAPI ServiceCtrlHandler(DWORD dwControl) //服务控制函数
{
switch (dwControl)
{

case SERVICE_CONTROL_PAUSE:
servicestatus.dwCurrentState = SERVICE_PAUSE_PENDING;
// TODO: add code to set dwCheckPoint & dwWaitHint
// This value need to try a lot to confirm 
// …
SetServiceStatus(servicestatushandle, &servicestatus);
// TODO: add code to pause the service
// not called in this service
// …
servicestatus.dwCurrentState = SERVICE_PAUSED;
// TODO: add code to set dwCheckPoint & dwWaitHint to 0
break;
case SERVICE_CONTROL_CONTINUE:
servicestatus.dwCurrentState = SERVICE_CONTINUE_PENDING;
// TODO: add code to set dwCheckPoint & dwWaitHint
SetServiceStatus(servicestatushandle, &servicestatus);
// TODO: add code to unpause the service
// not called in this service
// …
servicestatus.dwCurrentState = SERVICE_RUNNING;
// TODO: add code to set dwCheckPoint & dwWaitHint to 0
break;
case SERVICE_CONTROL_STOP:
servicestatus.dwCurrentState = SERVICE_STOP_PENDING;
// TODO: add code to set dwCheckPoint & dwWaitHint
SetServiceStatus(servicestatushandle, &servicestatus);
// TODO: add code to stop the service
Stop();
servicestatus.dwCurrentState = SERVICE_STOPPED;
// TODO: add code to set dwCheckPoint & dwWaitHint to 0
break;
case SERVICE_CONTROL_SHUTDOWN:
// TODO: add code for system shutdown
// as quick as possible
break;
case SERVICE_CONTROL_INTERROGATE:
// TODO: add code to set the service status
// …
servicestatus.dwCurrentState = SERVICE_RUNNING;
break;
}
SetServiceStatus(servicestatushandle, &servicestatus);
}

//安装服务函数 

//OpenSCManager函数是于创立一个服务目标(CreateService),并且把它们在到中使调用的API
//打开服务管理数据库

SC_HANDLE schService;
SC_HANDLE schSCManager;
schSCManager=OpenSCManager(
NULL, //本地计算机
NULL, //默认的数据库
SC_MANAGER_ALL_ACCESS //要求具有的访问权
);

//创建过程

CreateService(
SC_HANDLE
hSCManager,//服务控制管理程序维护的注册数据库的句柄,由系统函数
OpenSCManager 返回 
LPCTSTR lpServiceName, //以NULL
结尾的劳务名,用于创造登记数据库中的第一字
LPCTSTR lpDisplayName, //以NULL 结尾的劳务名,用于用户界面标识服务
DWORD dwDesiredAccess, //指定服务返回路
DWORD dwServiceType, //指定服务类型
DWORD dwStartType, //指定何时起步服务
DWORD dwErrorControl, //指定服务启动失败的要紧程度
LPCTSTR lpBinaryPathName, //指定服务程序二进制文件的路子
LPCTSTR lpLoadOrderGroup, //指定顺序装入的劳动组名
LPDWORD lpdwTagId, //忽略,NULL
LPCTSTR lpDependencies, //指定启动该服务前须优先启动之劳动或者服务组
LPCTSTR lpServiceStartName, //以NULL
结尾的字符串,指定服务帐号。如是NULL,则代表用 LocalSystem 帐号 
LPCTSTR lpPassword //以NULL
结尾的字符串,指定相应之口令。为NULL表示无口。
但使用LocalSystem时填NULL

schService=CreateService(
schSCManager, //服务管理数据库句柄
TEXT(SZSERVICENAME), //服务名
TEXT(SZAPPNAME), //用于展示服务的标识
SERVICE_ALL_ACCESS, //响应所有的拜访请求
SERVICE_WIN32_OWN_PROCESS, //服务类型
SERVICE_DEMAND_START, //启动类型
SERVICE_ERROR_NORMAL, //错误决定项目
szPath, //服务程序磁盘文件的路子
NULL, //服务不属任何组
NULL, //没有tag标识符
NULL, //启动服务所依赖之劳动要服务组,这里只有是一个空字符串
NULL, //LocalSystem 帐号
NULL);

除去服务经常调用
DeleteService;它仅来一个参数(服务句柄)。我们而划分四步成功
1)、打开SCM句柄。
2)、打开要刨除的劳务。
3)、检查时服务之状态确保服务已停。
4)、删除服务并关闭所有打开的句柄。下面是同等段删除服务的次第。

SC_HANDLE Service,scm;
SERVICE_STATUS status;
BOOL success;

scm = OpenSCManager(NULL,NULL,SC_MANAGER_ENUMERATE_SERVICE);
//打开SCM句柄。

//打开要删减的服务
Service = OpenService(scm,pszServiceName,SERVICE_ALL_ACCESS|DELETE);

//检查时劳动的状态确保服务一度终止
if (!Service){

cout<<“OpenService ERROR:”<<GetLastError()<<endl;
CloseServiceHandle(Service);
CloseServiceHandle(scm);
return false;
}

success = QueryServiceStatus(Service,&status);
if (!success){

cout<<“QueryServiceStatus
ERROR:”<<GetLastError()<<endl;
CloseServiceHandle(Service);
CloseServiceHandle(scm);
return false;
}

if (status.dwCurrentState!=SERVICE_STOPPED)
{
success = ControlService(Service,SERVICE_CONTROL_STOP,&status);
if (!success){
cout<<“ControlService ERROR:”<<GetLastError()<<endl;
CloseServiceHandle(Service);
CloseServiceHandle(scm);
return false;
}
}
//删除服务
success = DeleteService(Service);

if (!success){

cout<<“DeleteService ERROR:”<<GetLastError()<<endl;

CloseServiceHandle(Service);
CloseServiceHandle(scm);
return false;
}
bb//关闭所有打开的句柄
CloseServiceHandle(Service);
CloseServiceHandle(scm);
return true;

 

相关文章