1. Opening a Policy Object Handle.
#include <windows.h> #include <ntsecapi.h> void AddPrivileges(PSID AccountSID, LSA_HANDLE PolicyHandle) { LSA_UNICODE_STRING lucPrivilege; NTSTATUS ntsResult; // Create an LSA_UNICODE_STRING for the privilege names. if (!InitLsaString(&lucPrivilege, L"SeServiceLogonRight")) { wprintf(L"Failed InitLsaString\n"); return; } ntsResult = LsaAddAccountRights( PolicyHandle, // An open policy handle. AccountSID, // The target SID. &lucPrivilege, // The privileges. 1 // Number of privileges. ); if (ntsResult == STATUS_SUCCESS) { wprintf(L"Privilege added.\n"); } else { wprintf(L"Privilege was not added - %lu \n", LsaNtStatusToWinError(ntsResult)); } }
#include <windows.h> bool InitLsaString( PLSA_UNICODE_STRING pLsaString, LPCWSTR pwszString ) { DWORD dwLen = 0; if (NULL == pLsaString) return FALSE; if (NULL != pwszString) { dwLen = wcslen(pwszString); if (dwLen > 0x7ffe) // String is too large return FALSE; } // Store the string. pLsaString->Buffer = (WCHAR *)pwszString; pLsaString->Length = (USHORT)dwLen * sizeof(WCHAR); pLsaString->MaximumLength= (USHORT)(dwLen+1) * sizeof(WCHAR); return TRUE; }
原文链接: https://www.cnblogs.com/zhanghu52030/p/9592929.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;
也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/392062
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!