安全描述符

安全描述符(英語:Security descriptors)是安全信息的數據結構,用於可安全(securable)的Windows對象,這些對象可以被唯一名稱辨識。安全描述符可用於任何命名對象,包括文件文件夾、共享、註冊表鍵、進程、線程、命名管道、服務、工作對象以及其他資源。[1]

簡介

安全描述符包含自主決定的存取控制串列(DACL),裡面包含有訪問控制項(ACE),因此可以允許或拒絕特定用戶或用戶組的訪問。它們還包含一個系統訪問控制列表(SACL)以控制對象訪問請求的日誌(logging)。[2][3]ACE可以顯式應用於對象,或者從父對象繼承。ACE的順序在ACL中很重要,拒絕訪問的ACE應該比允許訪問的ACE更早出現。安全描述符還包含對象所有者。

強制完整性控制就是通過新類型的ACE在安全描述符上實現。[4]

應用

文件和文件夾的權限可以使用各種工具編輯,這包括Windows ExplorerWMI,以及命令行工具如Cacls、XCacls、ICacls英語Cacls#icacls、SubInACL[5]免費Win32控制台FILEACL[6][7]自由實用工具SetACL英語SetACL,以及其他實用工具。要編輯一個安全描述符,用戶需要有該對象的WRITE_DAC訪問權限[8],該權限通常默認授予管理員和該對象的所有者。

數據結構

typedef struct _SECURITY_DESCRIPTOR {
  UCHAR  Revision;
  UCHAR  Sbz1;
  SECURITY_DESCRIPTOR_CONTROL  Control; //其自身的一些控制位
  PSID  Owner; //Owner安全标识符(Security identifiers) 相当于UUID,标识用户、用户群、计算机帐户
  PSID  Group; //Group安全标识符(Security identifiers) 相当于UUID
  PACL  Sacl; //(System Access Control List),其指出了在该对象上的一组存取方式(如,读、写、运行等)的存取控制权限细节的列表。
  PACL  Dacl; //(Discretionary Access Control List),其指出了允许和拒绝某用户或用户组的存取控制列表。 如果一个对象没有DACL,那么就是说这个对象是任何人都可以拥有完全的访问权限。 
} SECURITY_DESCRIPTOR, *PISECURITY_DESCRIPTOR;

typedef struct _ACL {
    BYTE  AclRevision;
    BYTE  Sbz1;
    WORD   AclSize;
    WORD   AceCount;
    WORD   Sbz2;
} ACL, *PACL;

取得對象上的安全設置,或修改對象上的安全設置的Windows API。如:GetNamedSecurityInfo, SetNamedSecurityInfo,GetSecurityInfo, SetSecurityInfo。

底層安全描述符函數:

  • 對於文件、目錄、郵槽命名管道,可以使用其專用函數GetFileSecurity和SetFileSecurity函數來取得或設置文件對象的SD,以設置其訪問權限。
  • 對於進程、線程、訪問token英語Access token文件映射對象信號量事件互斥鎖可等待定時器,使用 GetKernelObjectSecurity與SetKernelObjectSecurity函數
  • 對於Window Station與桌面,使用GetUserObjectSecurity與SetUserObjectSecurity函數
  • 對於註冊表鍵,使用RegGetKeySecurity與RegSetKeySecurity函數
  • 對於Windows服務對象,使用QueryServiceObjectSecurity and SetServiceObjectSecurity函數
  • 對於打印機對象,使用GetPrinter and SetPrinter函數的PRINTER_INFO_2結構參數。
  • 對於網絡共享,使用NetShareGetInfo and NetShareSetInfo 的網絡502級別。
  • 對於進程創建的私有對象,使用CreatePrivateObjectSecurity, DestroyPrivateObjectSecurity, GetPrivateObjectSecurity and SetPrivateObjectSecurity函數

例子

#include <windows.h>

void main(void)
{
	SECURITY_ATTRIBUTES sa;  //和文件有关的安全结构
	SECURITY_DESCRIPTOR sd;  //声明一个SD

	BYTE aclBuffer[1024];
	PACL pacl = (PACL)&aclBuffer; //声明一个ACL,长度是1024

	BYTE sidBuffer[100];
	PSID psid = (PSID)&sidBuffer;  //声明一个SID,长度是100

	DWORD sidBufferSize = 100;
	char domainBuffer[80];
	DWORD domainBufferSize = 80;
	SID_NAME_USE snu;
	HANDLE file;

	//初始化一个SD
	InitializeSecurityDescriptor(&sd, SECURITY_DESCRIPTOR_REVISION);

	//初始化一个ACL
	InitializeAcl(pacl, 1024, ACL_REVISION);

	//查找一个用户hchen,并取该用户的SID
	LookupAccountName(0, "uidp1078", psid,&sidBufferSize, domainBuffer,&domainBufferSize, &snu);

	//设置该用户的Access-Allowed的ACE,其权限为“所有权限”
	AddAccessAllowedAce(pacl, ACL_REVISION, GENERIC_ALL, psid);

	//把ACL设置到SD中
	SetSecurityDescriptorDacl(&sd, TRUE, pacl, FALSE);

	//把SD放到文件安全结构SA中
	sa.nLength = sizeof(SECURITY_ATTRIBUTES);
	sa.bInheritHandle = FALSE;
	sa.lpSecurityDescriptor = &sd;

	//创建文件
	file = CreateFile("d:\\testfile",0, 0, &sa, CREATE_NEW, FILE_ATTRIBUTE_NORMAL, 0);

	CloseHandle(file);
}

參見

參考資料

  1. ^ Securable Objects. Microsoft. 2008-04-24 [2008-07-16]. (原始內容存檔於2017-12-22). 
  2. ^ What Are Security Descriptors and Access Control Lists?. Microsoft. [2008-07-16]. (原始內容存檔於2008-05-05). 
  3. ^ DACLs and ACEs. Microsoft. 2008-04-24 [2008-07-16]. (原始內容存檔於2017-10-08). 
  4. ^ https://msdn.microsoft.com/en-us/library/bb625957.aspx頁面存檔備份,存於網際網路檔案館) What is the Windows Integrity Mechanism?
  5. ^ SubInACL home page. [2016-06-23]. (原始內容存檔於2010-09-08). 
  6. ^ FILEACL home page. [2016-06-23]. (原始內容存檔於2012-08-29). 
  7. ^ FILEACL v3.0.1.6. Microsoft. 2004-03-23 [2008-07-25]. (原始內容存檔於2008-04-16). 
  8. ^ ACCESS_MASK Data Type. Microsoft. 2008-04-24 [2008-07-23]. (原始內容存檔於2017-12-22). 

外部連結