WIndows via C/C++ 学习(12)权限上下文
生活随笔
收集整理的這篇文章主要介紹了
WIndows via C/C++ 学习(12)权限上下文
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
摘抄了 Windows via C/C++ 上的一段代碼,一個函數——GetProcessElevation,返回安全令牌的提升類型和一個表示當前是否運行在管理員身份下。
BOOL GetProcesElevation(TOKEN_ELEVATION_TYPE *pElevation, BOOL *pIsAdmin) {HANDLE hToken = NULL;DWORD dwSize;// 獲得當前進程令牌if (!OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, &hToken))return FALSE;BOOL b_Result = FALSE;// 檢索提升類型信息if (GetTokenInformation(hToken, TokenElevationType, pElevation, sizeof(TOKEN_ELEVATION_TYPE), &dwSize)){if(*pElevation == TokenElevationTypeLimited){// 創建 Administrator 組相應的 SIDBYTE adminSID[SECURITY_MAX_SID_SIZE];dwSize = sizeof(adminSID);CreateWellKnownSid(WinBuiltinAdministratorsSid, NULL, adminSID, &dwSize);// 獲得鏈接令牌的句柄HANDLE hUnfilteredToken = NULL;GetTokenInformation(hToken, TokenLinkedToken, (LPVOID)&hUnfilteredToken, sizeof(HANDLE), &dwSize);// 檢測令牌是否包含管理員SIDif(CheckTokenMembership(hUnfilteredToken, &adminSID, pIsAdmin))b_Result = TRUE;CloseHandle(hUnfilteredToken);}else{*pIsAdmin = IsUserAnAdmin();b_Result = TRUE;}CloseHandle(hToken);return b_Result;} }轉載于:https://www.cnblogs.com/Fly-pig/archive/2011/01/21/1941189.html
總結
以上是生活随笔為你收集整理的WIndows via C/C++ 学习(12)权限上下文的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: /bin/sh^M:损坏的解释器: No
- 下一篇: 指针01 - 零基础入门学习C语言41