Partilhar via


Determinando a ACL de um objeto

Você pode usar o depurador para examinar a ACL (lista de controle de acesso) de um objeto .

O método a seguir poderá ser usado se você estiver executando a depuração de kernel. Para usá-lo enquanto estiver executando a depuração do modo de usuário, você precisa redirecionar o controle para um depurador de kernel. Consulte Controlando o depurador de User-Mode do Depurador do Kernel para obter detalhes.

Primeiro, use a extensão do depurador de objetos ! com o nome do objeto em questão:

kd> !object \BaseNamedObjects\AgentToWkssvcEvent
Object: ffbb8a98  Type: (80e30e70) Event
    ObjectHeader: ffbb8a80
    HandleCount: 2  PointerCount: 3
    Directory Object: e14824a0  Name: AgentToWkssvcEvent

Isso mostra que o cabeçalho do objeto tem 0xFFBB8A80 de endereço. Use o comando dt (Tipo de Exibição) com este endereço e o nome da estrutura nt!_OBJECT_HEADER :

kd> dt nt!_OBJECT_HEADER ffbb8a80
   +0x000 PointerCount     : 3
   +0x004 HandleCount      : 2
   +0x004 NextToFree       : 0x00000002
 +0x008 Type             : 0x80e30e70
   +0x00c NameInfoOffset   : 0x10 '
 +0x00d HandleInfoOffset : 0 '
   +0x00e QuotaInfoOffset  : 0 '
   +0x00f Flags            : 0x20 ' '
   +0x010 ObjectCreateInfo : 0x8016b460
   +0x010 QuotaBlockCharged : 0x8016b460
   +0x014 SecurityDescriptor : 0xe11f08b6
   +0x018 Body             : _QUAD

O valor do ponteiro do descritor de segurança é mostrado como 0xE11F08B6. Os 3 bits mais baixos desse valor representam um deslocamento após o início dessa estrutura, portanto, você deve ignorá-los. Em outras palavras, a estrutura de SECURITY_DESCRIPTOR realmente começa em 0xE11F08B6 & ~0x7. Use a extensão !sd neste endereço:

kd> !sd e11f08b0
->Revision: 0x1
->Sbz1    : 0x0
->Control : 0x8004
            SE_DACL_PRESENT
 SE_SELF_RELATIVE
->Owner   : S-1-5-32-544
->Group   : S-1-5-18
->Dacl    : 
->Dacl    : ->AclRevision: 0x2
->Dacl    : ->Sbz1       : 0x0
->Dacl    : ->AclSize    : 0x44
->Dacl    : ->AceCount   : 0x2
->Dacl    : ->Sbz2       : 0x0
->Dacl    : ->Ace[0]: ->AceType: ACCESS_ALLOWED_ACE_TYPE
->Dacl    : ->Ace[0]: ->AceFlags: 0x0
->Dacl    : ->Ace[0]: ->AceSize: 0x14
->Dacl    : ->Ace[0]: ->Mask : 0x001f0003
->Dacl    : ->Ace[0]: ->SID: S-1-5-18

->Dacl    : ->Ace[1]: ->AceType: ACCESS_ALLOWED_ACE_TYPE
->Dacl    : ->Ace[1]: ->AceFlags: 0x0
->Dacl    : ->Ace[1]: ->AceSize: 0x18
->Dacl    : ->Ace[1]: ->Mask : 0x00120001
->Dacl    : ->Ace[1]: ->SID: S-1-5-32-544

->Sacl    :  is NULL

Isso exibe as informações de segurança desse objeto.