除了schSCManager
and szPath
变量,all您传递给的其他变量CreateService()
尚未初始化,它们包含随机值。这对于psz...
变量,因为它们是指针,所以您可以有效地将随机内存地址传递给CreateService()
。这就是为什么你会得到一个ERROR_INVALID_ADDRESS
error.
您需要初始化变量!
pszServiceName
需要指向包含所需服务名称的以空结尾的字符串。
pszDisplayName
需要指向包含所需服务显示名称的以空结尾的字符串。
dwStartType
需要包含有效的起始类型整数值。
pszDependencies
需要为 NULL,或者指向一个以双 null 结尾的字符串,其中包含您的服务所依赖的以 null 分隔的服务名称列表。
pszAccount
需要为 NULL 或指向包含服务运行所需的用户帐户的以 null 结尾的字符串。
pszPassword
需要为 NULL 或指向包含密码的以 null 结尾的字符串pszAccount
帐户。
Edit:您最好完全删除变量并将所需的值直接传递给CreateService()
。尝试这个:
#include "stdafx.h"
void __cdecl _tmain(int argc, TCHAR *argv[])
{
wchar_t szPath[MAX_PATH+1];
SC_HANDLE schSCManager = NULL;
SC_HANDLE schService = NULL;
if (GetModuleFileName(NULL, szPath, ARRAYSIZE(szPath)) == 0)
{
wprintf(L"GetModuleFileName failed w/err 0x%08lx\n", GetLastError());
goto Cleanup;
}
// Open the local default service control manager database
schSCManager = OpenSCManager(NULL, NULL, SC_MANAGER_CONNECT | SC_MANAGER_CREATE_SERVICE);
if (schSCManager == NULL)
{
wprintf(L"OpenSCManager failed w/err 0x%08lx\n", GetLastError());
goto Cleanup;
}
// Install the service into SCM by calling CreateService
schService = CreateService(
schSCManager, // SCManager database
L"Win32_Service, // Name of service
L"My Service, // Name to display
SERVICE_QUERY_STATUS, // Desired access
SERVICE_WIN32_OWN_PROCESS, // Service type
SERVICE_DEMAND_START, // Service start type
SERVICE_ERROR_NORMAL, // Error control type
szPath, // Service's binary
NULL, // No load ordering group
NULL, // No tag identifier
NULL, // No Dependencies
L"NT AUTHORITY\\LocalService", // Service running account
NULL // No Password of the account
);
if (schService == NULL)
{
wprintf(L"CreateService failed w/err 0x%08lx\n", GetLastError());
goto Cleanup;
}
wprintf(L"Service is installed.\n");
Cleanup:
// Centralized cleanup for all allocated resources.
if (schService)
{
CloseServiceHandle(schService);
schService = NULL;
}
if (schSCManager)
{
CloseServiceHandle(schSCManager);
schSCManager = NULL;
}
}