C++ windows管理员权限运行程序

我们已用户权限运行程序,有时候需要在指定的路径下修改文件,而因为没有管理员权限导致失败。此时,我们可以使用管理员权限运行一个新的进程,用这个新的进程来执行修改任务。

 判断是否具有管理员权限

//判断管理员权限
bool IsAdmin()
{
	BOOL b;
	SID_IDENTIFIER_AUTHORITY NtAuthority = SECURITY_NT_AUTHORITY;
	PSID AdministratorsGroup;
	b = AllocateAndInitializeSid(&NtAuthority, 2, SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS, 0, 0, 0, 0, 0, 0, &AdministratorsGroup);
	if (b)
	{
		if (!CheckTokenMembership(NULL, AdministratorsGroup, &b))
		{
			b = FALSE;
		}
		FreeSid(AdministratorsGroup);
	}

	return(b);
}

 判断系统版本是否是win7以上

bool IsAboveVistaVersion()  //判断系统版本是否是win7以上
{
	OSVERSIONINFOEX WinVersion;
	ZeroMemory(&WinVersion, sizeof(OSVERSIONINFOEX));
	WinVersion.dwOSVersionInfoSize = sizeof(OSVERSIONINFOEX);
	BOOL flag = (BOOL)GetVersionEx((OSVERSIONINFO *)&WinVersion);
	assert(flag);

	if (WinVersion.dwMajorVersion < 6)
		return false;

	if (WinVersion.dwMajorVersion == 6 && WinVersion.dwMinorVersion == 1)
		return false;

	if (WinVersion.dwMajorVersion == 6 && WinVersion.dwMinorVersion >= 2)
		return true;

	if (WinVersion.dwMajorVersion > 6)
		return true;

	return true;
}

以管理员运行程序:

wstring GetExePath()
{
	WCHAR buf[MAX_PATH] = { 0 };
	wstring strPath;
	GetModuleFileName(nullptr, buf, MAX_PATH);
	strPath = buf;
	return strPath;
}
//是否初次运行
bool IsFirstRun(string sFileName, string sAppName, string sKeyName)
{
	bool bRet = false;
	char cModulePath[MAX_PATH] = { 0 };
	GetModuleFileNameA(NULL, cModulePath, MAX_PATH);
	PathRemoveFileSpecA(cModulePath);

	string strPath = cModulePath;
	strPath += "\\" + sFileName;

	int nIndex = GetPrivateProfileIntA(sAppName.c_str(), sKeyName.c_str(), 0, strPath.c_str());
	if (nIndex == 0)
	{
		bRet = true;
		WritePrivateProfileStringA(sAppName.c_str(), sKeyName.c_str(), "1", strPath.c_str());
	}
	if (!IsAdmin() && IsAboveVistaVersion())
	{
		wstring exePath(GetExePath());
		SHELLEXECUTEINFO sei = { sizeof(SHELLEXECUTEINFO) };
		sei.fMask = SEE_MASK_NOCLOSEPROCESS;
		sei.lpVerb = L"runas";
		sei.lpFile = exePath.c_str();
		sei.lpParameters = L"FirstRun";
		if (!ShellExecuteEx(&sei))
		{
			DWORD dwStatus = GetLastError();
			if (dwStatus == ERROR_CANCELLED)
			{
				//debug_showmessage("提升权限出错\n");
			}
		}
	}

	return bRet;
}

此时使用管理员权限开启一个进程,并带有一个参数“FirstRun”

wstring strCmd = szArglist[1];
if (strCmd == L"FirstRun")//第一次运行时调用
		{
			SetFirstRun("set.ini","Install","FirstRun");
			return 0;
		}

在该进程main函数中,判断参数是否为“FirstRun”,如果是则执行需要管理员权限的代码

C++中,通常通过操作系统级别的API来以管理员权限运行CMD脚本(批处理文件,如.bat或.cmd)。这需要利用系统函数如CreateProcess(),并设置适当的权限标志。以下是一个简化的示例,展示了如何创建一个进程运行管理员权限的CMD: ```cpp #include <windows.h> bool RunAsAdmin(const std::wstring& scriptPath) { STARTUPINFO si = {0}; PROCESS_INFORMATION pi = {0}; // 设置启动信息 si.cb = sizeof(STARTUPINFO); si.dwFlags = STARTF_USESHOWWINDOW; si.wShowWindow = SW_HIDE; // 隐藏窗口 // 创建进程信息结构 ZeroMemory(&pi, sizeof(PROCESS_INFORMATION)); // 运行命令的命令字符串,这里以cmd.exe /c 指定脚本路径 wchar_t command[] = L"cmd.exe /c start ""%s"""; // 使用管理员权限创建进程 if (!CreateProcess(NULL, // 父进程句柄 (LPCWSTR)(fmtwprintf(command, L"%ls", scriptPath.c_str())), // 要运行程序 NULL, // 不指定父进程 NULL, // 不指定父进程环境 TRUE, // 是否继承父进程的令牌 CREATE_NEW_CONSOLE | CREATE_UNICODE_ENVIRONMENT | DETACHED_PROCESS | SYNCHRONIZE, // 权限标志 NULL, // 环境变量 NULL, // 工作目录 &si, // 启动信息 &pi)) { DWORD errorCode = GetLastError(); // 输出错误信息 return false; } // 关闭进程句柄,因为创建了新的进程 CloseHandle(pi.hThread); CloseHandle(pi.hProcess); return true; } // 使用方法 if (RunAsAdmin(L"C:\\path\\to\\your_script.bat")) { std::cout << "脚本已成功以管理员身份运行。\n"; } else { std::cerr << "无法以管理员权限运行脚本,错误代码: " << GetLastError() << "\n"; } ``` 请注意,这只是一个基本示例,并未涵盖所有可能的情况,实际使用时可能会有额外的安全检查和错误处理。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值