【Windows】权限(Privilege Constants)

阅读这篇文章你可以了解:

  1. Constants 是什么
  2. windows 提权时常用的 Constants
    微软官方文档:Privilege Constants (Winnt.h) - Win32 apps | Microsoft Learn

0x01 介绍

Constants

Constants 即常用权限对应的字符串,微软通过宏定义的方式对 Constants 进行了罗列。如常见使用的 SeDebugPrivilege 对应的宏定义即为 SE_DEBUG_NAME,下表所示为常见的 Constant 对应的 value 和描述。

Constant/value Description
SE_ASSIGNPRIMARYTOKEN_NAME
TEXT(“SeAssignPrimaryTokenPrivilege”)
Required to assign the primary token of a process. User Right: Replace a process-level token.
SE_AUDIT_NAME
TEXT(“SeAuditPrivilege”)
Required to generate audit-log entries. Give this privilege to secure servers. User Right: Generate security audits.
SE_BACKUP_NAME
TEXT(“SeBackupPrivilege”)
Required to perform backup operations. This privilege causes the system to grant all read access control to any file, regardless of the access control list (ACL) specified for the file. Any access request other than read is still evaluated with the ACL. This privilege is required by the RegSaveKey and RegSaveKeyExfunctions. The following access rights are granted if this privilege is held: READ_CONTROLACCESS_SYSTEM_SECURITYFILE_GENERIC_READFILE_TRAVERSEUser Right: Back up files and directories. If the file is located on a removable drive and the “Audit Removable Storage” is enabled, the SE_SECURITY_NAME is required to have ACCESS_SYSTEM_SECURITY.
SE_CHANGE_NOTIFY_NAME
TEXT(“SeChangeNotifyPrivilege”)
Required to receive notifications of changes to files or directories. This privilege also causes the system to skip all traversal access checks. It is enabled by default for all users. User Right: Bypass traverse checking.
SE_CREATE_GLOBAL_NAME
TEXT(“SeCreateGlobalPrivilege”)
Required to create named file mapping objects in the global namespace during Terminal Services sessions. This privilege is enabled by default for administrators, services, and the local system account. User Right: Create global objects.
SE_CREATE_PAGEFILE_NAME
TEXT(“SeCreatePagefilePrivilege”)
Required to create a paging file. User Right: Create a pagefile.
SE_CREATE_PERMANENT_NAME
TEXT(“SeCreatePermanentPrivilege”)
Required to create a permanent object. User Right: Create permanent shared objects.
SE_CREATE_SYMBOLIC_LINK_NAME
TEXT(“SeCreateSymbolicLinkPrivilege”)
Required to create a symbolic link. User Right: Create symbolic links.
**SE_CREATE_TOKEN_NAME
**TEXT(“SeCreateTokenPrivilege”)
Required to create a primary token. User Right: Create a token object. You cannot add this privilege to a user account with the “Create a token object” policy. Additionally, you cannot add this privilege to an owned process using Windows APIs.Windows Server 2003 and Windows XP with SP1 and earlier: Windows APIs can add this privilege to an owned process.
**SE_DEBUG_NAME
**TEXT(“SeDebugPrivilege”)
Required to debug and adjust the memory of a process owned by another account. User Right: Debug programs.
**SE_DELEGATE_SESSION_USER_IMPERSONATE_NAME
**TEXT(“SeDelegateSessionUserImpersonatePrivilege”)
Required to obtain an impersonation token for another user in the same session. User Right: Impersonate other users.
SE_ENABLE_DELEGATION_NAME
TEXT(“SeEnableDelegationPrivilege”)
Required to mark user and computer accounts as trusted for delegation. User Right: Enable computer and user accounts to be trusted for delegation.
SE_IMPERSONATE_NAME
TEXT(“SeImpersonatePrivilege”)
Required to impersonate. User Right: Impersonate a client after authentication.
SE_INC_BASE_PRIORITY_NAME
TEXT(“SeIncreaseBasePriorityPrivilege”)
Required to increase the base priority of a process. User Right: Increase scheduling priority.
SE_INCREASE_QUOTA_NAME
TEXT(“SeIncreaseQuotaPrivilege”)
Required to increase the quota assigned to a process. User Right: Adjust memory quotas for a process.
**SE_INC_WORKING_SET_NAME
**TEXT(“SeIncreaseWorkingSetPrivilege”)
Required to allocate more memory for applications that run in the context of users. User Right: Increase a process working set.
**SE_LOAD_DRIVER_NAME
**TEXT(“SeLoadDriverPrivilege”)
Required to load or unload a device driver. User Right: Load and unload device drivers.
**SE_LOCK_MEMORY_NAME
**TEXT(“SeLockMemoryPrivilege”)
Required to lock physical pages in memory. User Right: Lock pages in memory.
**SE_MACHINE_ACCOUNT_NAME
**TEXT(“SeMachineAccountPrivilege”)
Required to create a computer account. User Right: Add workstations to domain.
SE_MANAGE_VOLUME_NAME
TEXT(“SeManageVolumePrivilege”)
Required to enable volume management privileges. User Right: Manage the files on a volume.
SE_PROF_SINGLE_PROCESS_NAME
TEXT(“SeProfileSingleProcessPrivilege”)
Required to gather profiling information for a single process. User Right: Profile single process.
SE_RELABEL_NAME
TEXT(“SeRelabelPrivilege”)
Required to modify the mandatory integrity level of an object. User Right: Modify an object label.
**SE_REMOTE_SHUTDOWN_NAME
**TEXT(“SeRemoteShutdownPrivilege”)
Required to shut down a system using a network request. User Right: Force shutdown from a remote system.
SE_RESTORE_NAME
TEXT(“SeRestorePrivilege”)
Required to perform restore operations. This privilege causes the system to grant all write access control to any file, regardless of the ACL specified for the file. Any access request other than write is still evaluated with the ACL. Additionally, this privilege enables you to set any valid user or group SID as the owner of a file. This privilege is required by the RegLoadKey function. The following access rights are granted if this privilege is held: WRITE_DACWRITE_OWNERACCESS_SYSTEM_SECURITYFILE_GENERIC_WRITEFILE_ADD_FILEFILE_ADD_SUBDIRECTORYDELETEUser Right: Restore files and directories. If the file is located on a removable drive and the “Audit Removable Storage” is enabled, the SE_SECURITY_NAME is required to have ACCESS_SYSTEM_SECURITY.
SE_SECURITY_NAME
TEXT(“SeSecurityPrivilege”)
Required to perform a number of security-related functions, such as controlling and viewing audit messages. This privilege identifies its holder as a security operator. User Right: Manage auditing and security log.
SE_SHUTDOWN_NAME
TEXT(“SeShutdownPrivilege”)
Required to shut down a local system. User Right: Shut down the system.
SE_SYNC_AGENT_NAME
TEXT(“SeSyncAgentPrivilege”)
Required for a domain controller to use the Lightweight Directory Access Protocol directory synchronization services. This privilege enables the holder to read all objects and properties in the directory, regardless of the protection on the objects and properties. By default, it is assigned to the Administrator and LocalSystem accounts on domain controllers. User Right: Synchronize directory service data.
SE_SYSTEM_ENVIRONMENT_NAME
TEXT(“SeSystemEnvironmentPrivilege”)
Required to modify the nonvolatile RAM of systems that use this type of memory to store configuration information. User Right: Modify firmware environment values.
SE_SYSTEM_PROFILE_NAME
TEXT(“SeSystemProfilePrivilege”)
Required to gather profiling information for the entire system. User Right: Profile system performance.
SE_SYSTEMTIME_NAME
TEXT(“SeSystemtimePrivilege”)
Required to modify the system time. User Right: Change the system time.
SE_TAKE_OWNERSHIP_NAME
TEXT(“SeTakeOwnershipPrivilege”)
Required to take ownership of an object without being granted discretionary access. This privilege allows the owner value to be set only to those values that the holder may legitimately assign as the owner of an object. User Right: Take ownership of files or other objects.
**SE_TCB_NAME
**TEXT(“SeTcbPrivilege”)
This privilege identifies its holder as part of the trusted computer base. Some trusted protected subsystems are granted this privilege. User Right: Act as part of the operating system.
**SE_TIME_ZONE_NAME
**TEXT(“SeTimeZonePrivilege”)
Required to adjust the time zone associated with the computer’s internal clock. User Right: Change the time zone.
SE_TRUSTED_CREDMAN_ACCESS_NAME
TEXT(“SeTrustedCredManAccessPrivilege”)
Required to access Credential Manager as a trusted caller. User Right: Access Credential Manager as a trusted caller.
SE_UNDOCK_NAME
TEXT(“SeUndockPrivilege”)
Required to undock a laptop. User Right: Remove computer from docking station.
**SE_UNSOLICITED_INPUT_NAME
**TEXT(“SeUnsolicitedInputPrivilege”)
Required to read unsolicited input from a terminal device. User Right: Not applicable.

0x02 用法

value不同,对应的操作和权限也不同,本文列举了有关 Privilege Constants 的一些使用方式。

LookupPrivilegeValue 查找权限

查找权限

1
2
3
4
5
6
7
8
9
10
11
BOOL EnablePrivilege()
{
LUID PrivilegeRequired ;
BOOL bRes = FALSE;

bRes = LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &PrivilegeRequired);

// ...

return bRes;
}

AdjustTokenPrivileges 修改权限

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
inline BOOL CToolhelp::EnablePrivilege(PCTSTR szPrivilege, BOOL fEnable) {

// Enabling the debug privilege allows the application to see
// information about service applications
BOOL fOk = FALSE; // Assume function fails
HANDLE hToken;

// Try to open this process's access token
if (OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES,
&hToken)) {

// Attempt to modify the given privilege
TOKEN_PRIVILEGES tp;
tp.PrivilegeCount = 1;
LookupPrivilegeValue(NULL, szPrivilege, &tp.Privileges[0].Luid);
tp.Privileges[0].Attributes = fEnable ? SE_PRIVILEGE_ENABLED : 0;
AdjustTokenPrivileges(hToken, FALSE, &tp, sizeof(tp), NULL, NULL);
fOk = (GetLastError() == ERROR_SUCCESS);

// Don't forget to close the token handle
CloseHandle(hToken);
}
return(fOk);
}

【Windows】权限(Privilege Constants)
https://hodlyounger.github.io/2023/10/27/A_OS/Windows/权限与会话/【权限】Privilege's constants/
作者
mingming
发布于
2023年10月27日
许可协议