SC_HANDLE WINAPI CreateService(
_In_ SC_HANDLE hSCManager,
_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
);
函数作用:创建一个服务对象,并把它添加进SCM数据库
参数:
1. hSCManager:SCM数据库句柄,同时该句柄需要具有SC_MANAGER_CREATE_SERVICE权限;
OpenSCManager
2. lpServiceName:要安装服务的名字,不可超过256个字符,不能含有/和字符,同时大小写敏感
3. lpDisplayName:服务显示出的名称
4. dwDesiredAccess:对服务的权限
5. dwServiceType:服务类型
Value | Meaning |
- SERVICE_ADAPTER
- 0x00000004
|
Reserved.
|
- SERVICE_FILE_SYSTEM_DRIVER
- 0x00000002
|
File system driver service.
|
- SERVICE_KERNEL_DRIVER
- 0x00000001
|
Driver service.
|
- SERVICE_RECOGNIZER_DRIVER
- 0x00000008
|
Reserved.
|
- SERVICE_WIN32_OWN_PROCESS
- 0x00000010
|
Service that runs in its own process.
|
- SERVICE_WIN32_SHARE_PROCESS
- 0x00000020
|
Service that shares a process with one or more other services. For more information, see Service Programs.
|
如果指定了 SERVICE_WIN32_OWN_PROCESS 或 SERVICE_WIN32_SHARE_PROCESS ,并且服务运行在LocalSystem上下文,你也可以指定下面的值:
Value | Meaning |
- SERVICE_INTERACTIVE_PROCESS
- 0x00000100
|
The service can interact with the desktop.
For more information, see Interactive Services.
|
6. dwStartType:服务启动选项
Value | Meaning |
- SERVICE_AUTO_START
- 0x00000002
|
A service started automatically by the service control manager during system startup. For more information, see Automatically Starting Services.
(在系统启动的时候,由SCM自动运行服务)
|
- SERVICE_BOOT_START
- 0x00000000
|
A device driver started by the system loader. This value is valid only for driver services.
(系统引导程序自动运行服务,只对driver services有效)
|
- SERVICE_DEMAND_START
- 0x00000003
|
A service started by the service control manager when a process calls the StartService function. For more information, see Starting Services on Demand.
(当一个程序调用StartService函数时,SCM启动服务)
|
- SERVICE_DISABLED
- 0x00000004
|
A service that cannot be started. Attempts to start the service result in the error code ERROR_SERVICE_DISABLED.
(一个不能启动的服务,尝试启动它时,会产生ERROR_SERVICE_DISABLED)
|
- SERVICE_SYSTEM_START
- 0x00000001
|
A device driver started by the IoInitSystem function. This value is valid only for driver services.
(一个由 IoInitSystem函数启动的服务)
|
7. dwErrorControl :服务错误处理方式
Value | Meaning |
- SERVICE_ERROR_CRITICAL
- 0x00000003
|
The startup program logs the error in the event log, if possible. If the last-known-good configuration is being started, the startup operation fails. Otherwise, the system is restarted with the last-known good configuration.
|
- SERVICE_ERROR_IGNORE
- 0x00000000
|
The startup program ignores the error and continues the startup operation.
|
- SERVICE_ERROR_NORMAL
- 0x00000001
|
The startup program logs the error in the event log but continues the startup operation.
|
- SERVICE_ERROR_SEVERE
- 0x00000002
|
The startup program logs the error in the event log. If the last-known-good configuration is being started, the startup operation continues. Otherwise, the system is restarted with the last-known-good configuration.
|
8. lpBinaryPathName:服务程序路径
驱动程序的完整路径,如果路径包含有空格,那么路径必须加引号,如"d:\my share\myservice.exe"应该为""d:\my share\myservice.exe"";
对于一个自动启动的服务,路径能够带有启动参数,比如"d:\myshare\myservice.exe arg1 arg2",这些参数被传递给服务入口(比如main函数);
如果另一台计算机上指定一个路径,共享必须可以访问由本地计算机的计算机帐户,因为这是在远程调用中使用的安全上下文。 但是,这项规定会影响本地计算机远程计算机中允许任何潜在的漏洞。 因此,最好使用一个本地文件。
9. lpLoadOrderGroup:
在加载顺序此服务所属的组的名称。 指定 NULL 或空字符串,如果该服务不属于组。 启动程序使用加载顺序组加载服务相对于其他组的指定顺序组。 加载顺序组列表包含在下面的注册表值:[HKEY_LOCAL_MACHINESystemCurrentControlSetControlServiceGroupOrder]
10. lpdwTagId
指向接收 lpLoadOrderGroup 参数中指定的组中唯一的标记值的变量。 如果不更改现有的标签,请指定 NULL。订购服务启动一个加载顺序通过在以下注册表值中指定标记顺序矢量的组中,您可以使用的标记:[HKEY_LOCAL_MACHINESystemCurrentControlSetControlGroupOrderList]。标记只能用于具有 SERVICE_BOOT_START 或启动类型的 SERVICE_SYSTEM_START 驱动程序服务。
11. lpDependencies
空分隔名称的服务或加载顺序组系统必须在这个服务开始之前的双空终止数组的指针。 如果服务没有任何依赖关系,请指定为 NULL 或空字符串。 一组依赖意味着如果至少一个组的成员运行后试图启动组的所有成员,可以运行此服务。当需要区分各服务由于服务和服务组共享相同的命名空间前缀与 SC_GROUP_IDENTIFIER 的组名时必须加上此参数。
12. lpServiceStartName
该服务应在其下运行的帐户的名称。 如果SERVICE_WIN32_OWN_PROCESS 服务类型DomainNameUserName窗体中使用一个帐户名。 服务进程将被作为此用户登录。 如果该帐户属于内置域,您可以指定.UserName。
如果为NULL此参数CreateService使用LocalSystem帐户。 如果服务类型指定 SERVICE_INTERACTIVE_PROCESS,该服务必须运行在LocalSystem帐户。
如果NTAUTHORITYLocalService此参数CreateService使用LocalService帐户。 如果NTAUTHORITYNetworkService参数CreateService使用NetworkService帐户。
共享的处理可以运行于任何用户。
如果服务类型 SERVICE_KERNEL_DRIVER 或 SERVICE_FILE_SYSTEM_DRIVER 名称是系统用来加载设备驱动程序的驱动程序对象名称。 如果该驱动程序将使用由IO系统创建的默认对象名称,请指定NULL。
可以将服务配置为使用一个托管的帐户或虚拟帐户。 如果该服务被配置为使用一个托管的服务帐户,名称是托管的服务帐户名称。 如果该服务被配置为使用一个虚拟帐户,作为NTSERVICEServiceName指定名称。 有关托管的服务帐户和虚拟帐户的详细信息请参阅服务帐户的分步指南。
WindowsServer2008、WindowsVista、WindowsServer2003 和WindowsXP2000:Windows7 和WindowsServer2008 R2 之前不支持托管的服务帐户和虚拟帐户。
13. lpPassword
由lpServiceStartName参数指定的帐户名的密码。 如果该帐户没有密码,或者如果在LocalService,NetworkService或LocalSystem帐户中运行该服务,请指定一个空字符串。 更多的信息请参阅服务记录列表。
如果托管的服务帐户或虚拟帐户名称的名称由lpServiceStartName参数指定的帐户名称lpPassword参数必须为NULL。
密码将被忽略,对驱动程序服务。
返回值
如果函数成功,返回值将是该服务的句柄。
如果函数失败,则返回值为 NULL。 若要扩展的错误了解调用GetLastError。
下面的错误代码可以由服务控制管理器设置。 其他错误代码可以设置的由服务控制管理器调用注册表函数。
返回值
|
描述
|
ERROR_ACCESS_DENIED
|
提供的hSCManager参数没有SC_MANAGER_CREATE_SERVICE权限。
|
ERROR_CIRCULAR_DEPENDENCY
|
存在循环嵌套的服务依赖关系。
|
ERROR_DUPLICATE_SERVICE_NAME
|
显示名称已在SCM中被其他服务注册为服务名称或显示名称。
|
ERROR_INVALID_HANDLE
|
提供的hSCManager参数无效。
|
ERROR_INVALID_NAME
|
提供的服务名称无效。
|
ERROR_INVALID_PARAMETER
|
其他参数无效。
|
ERROR_INVALID_SERVICE_ACCOUNT
|
由lpServiceStartName参数指定的用户名不存在。
|
ERROR_SERVICE_EXISTS
|
已存在完全相同的服务。
|
说明:
(1)CreateService函数创建一个服务对象并将其安装在SCM数据库中,同时在注册表以下位置中创建同名键值:[HKEY_LOCAL_MACHINESystemCurrentControlSetServices]
由CreateService、ChangeServiceConfig和ChangeServiceConfig2等函数创建服务时提供的服务相关信息就存放于这个键值中。以下是一些键值的描述:
值
|
描述
|
DependOnGroup
|
由lpDependencies参数指定的依赖性服务群组,包含加载顺序。
|
DependOnService
|
由lpDependencies参数指定的依赖性服务。
|
Description
|
由ChangeServiceConfig2函数写入的描述信息。
|
DisplayName
|
由lpDisplayName参数指定的服务显示名称。
|
ErrorControl
|
由dwErrorControl参数指定的纠错方案。
|
FailureActions
|
由ChangeServiceConfig2函数写入的异常信息。
|
Group
|
由lpLoadOrderGroup参数指定的服务群组,包含加载顺序。
|
ImagePath
|
由lpBinaryPathName参数指定的服务程序文件位置。
|
ObjectName
|
由lpServiceStartName参数指定的名称。
|
Start
|
由dwStartType参数指定的服务启动时间。
|
Tag
|
由lpdwTagId参数指定的识别信息。
|
Type
|
由dwServiceType参数指定的服务类型。
|
服务安装程序可以创建子键来提供更多额外的信息。
(2)CreateService函数返回的句柄只能由调用它的进程使用,可以调用CloseServiceHandle函数来关掉这个句柄。若创建进程共享服务,请不要随意调用可能影响其他进程的函数,如ExitProcess。另外,请不要卸载服务程序的动态链接库(DLL文件)。
本文链接:http://www.cnblogs.com/cposture/p/4717479.html