用vs2015 C/C++创建windows守护进程

创建服务程序可以参考https://blog.csdn.net/chenyujing1234/article/details/8023816

此处为调用exe文件,在进程中和前台都可以显示。以下部分为主要代码。

BOOL Sever::RunProcess(const std::string path)
{
	STARTUPINFO si = { 0 };
	// 进程信息 
	PROCESS_INFORMATION pi = { 0 };

	si.cb = sizeof(si);
	// 获得当前Session ID   
	DWORD dwSessionID = WTSGetActiveConsoleSessionId();
	HANDLE hToken = NULL;
	// 获得当前Session的用户令牌        
	if (::WTSQueryUserToken(dwSessionID, &hToken) == FALSE)
	{
		return FALSE;
	}

	HANDLE hDuplicatedToken = NULL;

	if (DuplicateTokenEx(hToken, MAXIMUM_ALLOWED, NULL, SecurityIdentification, TokenPrimary, &hDuplicatedToken) == FALSE)
	{
		return FALSE;
	}

	// 创建用户Session环境   
	LPVOID lpEnvironment = NULL;

	if (CreateEnvironmentBlock(&lpEnvironment, hDuplicatedToken, FALSE) == FALSE)
	{
		return FALSE;
	}

	//WCHAR lpszClientPath[MAX_PATH];
	wchar_t * lpszClientPath = new wchar_t[MAX_PATH];
	swprintf(lpszClientPath, MAX_PATH,L"%S ", path.c_str());//注意大写S。
// 	if (GetModuleFileName(NULL, lpszClientPath, MAX_PATH) == 0)
// 	{
// 		return FALSE;
// 	}

	//PathRemoveFileSpec(lpszClientPath); 
	wcscat(lpszClientPath,L" ");

	fprintf(file, "path! %s\n", lpszClientPath);
	DWORD dwCreationFlags = NORMAL_PRIORITY_CLASS | CREATE_NEW_CONSOLE | CREATE_UNICODE_ENVIRONMENT;
	if (CreateProcessAsUser(hDuplicatedToken, lpszClientPath, NULL, NULL, NULL, FALSE, dwCreationFlags, lpEnvironment, NULL, &si, &pi) == TRUE)
	{
		fprintf(file, "CreateProcessAsUser ok!\n");
	}
	else
	{
		fprintf(file, "CreateProcessAsUser false!\n");
	}

	CloseHandle(pi.hProcess);
	CloseHandle(pi.hThread);
	delete[]lpszClientPath;
	lpszClientPath = NULL;
	return TRUE;
}

注:1.如果服务启动后就自动关闭有可能系统缺少必要的库可以用 DirectX_Repair修复工具进行修复

 

2.一定不要用远程桌面进行启动。这样通过调用WTSQueryUserToken()在会话上获取用户令牌,错误代码为1008.则导致程序无法正常运行.

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的假脱机打印系统的实现,使用了C++语言和Windows API: ``` #include <iostream> #include <windows.h> #include <string> using namespace std; // 共享内存结构体 struct SharedMemory { HANDLE mutex; // 互斥量 HANDLE empty; // 空闲区域信号量 HANDLE full; // 已占用区域信号量 int read; // 读指针 int write; // 写指针 char data[1024]; // 数据区 }; // 输出进程 DWORD WINAPI OutputThread(LPVOID lpParameter) { string filename; // 输出文件名 SharedMemory* sharedMem = (SharedMemory*)lpParameter; while (true) { // 生输出文件名 filename = "output" + to_string(rand() % 100) + ".txt"; // 写入数据到输出文件 ofstream outFile(filename); outFile << "This is output data." << endl; outFile.close(); // 写入文件名到共享内存 WaitForSingleObject(sharedMem->empty, INFINITE); // 等待空闲区域 WaitForSingleObject(sharedMem->mutex, INFINITE); // 获取互斥量 strcpy(sharedMem->data + sharedMem->write, filename.c_str()); sharedMem->write = (sharedMem->write + filename.length() + 1) % 1024; ReleaseMutex(sharedMem->mutex); // 释放互斥量 ReleaseSemaphore(sharedMem->full, 1, NULL); // 发送已占用区域信号量 } return 0; } // 打印守护进程 DWORD WINAPI PrintThread(LPVOID lpParameter) { SharedMemory* sharedMem = (SharedMemory*)lpParameter; char filename[256]; while (true) { // 从共享内存中读取文件名 WaitForSingleObject(sharedMem->full, INFINITE); // 等待已占用区域信号量 WaitForSingleObject(sharedMem->mutex, INFINITE); // 获取互斥量 strcpy(filename, sharedMem->data + sharedMem->read); sharedMem->read = (sharedMem->read + strlen(filename) + 1) % 1024; ReleaseMutex(sharedMem->mutex); // 释放互斥量 ReleaseSemaphore(sharedMem->empty, 1, NULL); // 发送空闲区域信号量 // 输出文件内容 ifstream inFile(filename); string line; while (getline(inFile, line)) { cout << line << endl; } inFile.close(); } return 0; } int main() { // 初始化随机数生器 srand(GetTickCount()); // 创建共享内存 HANDLE hMapFile = CreateFileMapping(INVALID_HANDLE_VALUE, NULL, PAGE_READWRITE, 0, sizeof(SharedMemory), TEXT("SharedMem")); SharedMemory* sharedMem = (SharedMemory*)MapViewOfFile(hMapFile, FILE_MAP_ALL_ACCESS, 0, 0, sizeof(SharedMemory)); // 初始化共享内存 sharedMem->mutex = CreateMutex(NULL, FALSE, TEXT("SharedMutex")); sharedMem->empty = CreateSemaphore(NULL, 1024, 1024, TEXT("SharedEmpty")); sharedMem->full = CreateSemaphore(NULL, 0, 1024, TEXT("SharedFull")); sharedMem->read = 0; sharedMem->write = 0; // 创建输出线程和打印线程 HANDLE hOutputThread = CreateThread(NULL, 0, OutputThread, sharedMem, 0, NULL); HANDLE hPrintThread = CreateThread(NULL, 0, PrintThread, sharedMem, 0, NULL); // 等待输出线程和打印线程结束 WaitForSingleObject(hOutputThread, INFINITE); WaitForSingleObject(hPrintThread, INFINITE); // 清理资源 CloseHandle(hMapFile); CloseHandle(sharedMem->mutex); CloseHandle(sharedMem->empty); CloseHandle(sharedMem->full); UnmapViewOfFile(sharedMem); return 0; } ``` 该程序创建了一个大小为1024字节的共享内存区域,用于存储输出文件名。输出进程循环生一个随机的输出文件名,并将文件名写入共享内存中。打印守护进程从共享内存中读取文件名,并输出文件内容到屏幕上。在共享内存的访问上,互斥量和信号量保证了数据的正确性和同步性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值