共用方式為


ConvertFrom-SddlString

將 SDDL 字串轉換為自訂物件。

語法

ConvertFrom-SddlString
                [-Sddl] <String>
                [-Type <Object>]
                [<CommonParameters>]

Description

Cmdlet 會將 ConvertFrom-SddlString 安全性描述元定義語言字串轉換成具有下列屬性的自定義 PSCustomObject 物件:Owner、Group、DiscretionaryAcl、SystemAcl 和 RawDescriptor。

擁有者、群組、DiscretionaryAcl 和 SystemAcl 屬性包含 SDDL 字串中所指定訪問許可權的可讀取文字表示法。

此 Cmdlet 已在 PowerShell 5.0 中引進。

範例

範例 1:將文件系統訪問許可權 SDDL 轉換為 PSCustomObject

$acl = Get-Acl -Path C:\Windows
ConvertFrom-SddlString -Sddl $acl.Sddl

第一個命令會 Get-Acl 使用 Cmdlet 來取得 C:\Windows 資料夾的安全性描述元,並將它儲存在變數中。

第二個命令會 ConvertFrom-SddlString 使用 Cmdlet 來取得 SDDL 字串串的文字表示法,該字串包含在代表安全性描述元之 物件的 Sddl 屬性中。

範例 2:將登錄訪問許可權 SDDL 轉換為 PSCustomObject

$acl = Get-Acl HKLM:\SOFTWARE\Microsoft\
ConvertFrom-SddlString -Sddl $acl.Sddl -Type RegistryRights

第一個命令會 Get-Acl 使用 Cmdlet 來取得 HKLM:\SOFTWARE\Microsoft\ 金鑰的安全性描述元,並將它儲存在變數中。

第二個命令會 ConvertFrom-SddlString 使用 Cmdlet 來取得 SDDL 字串串的文字表示法,該字串包含在代表安全性描述元之 物件的 Sddl 屬性中。

它會使用 -Type 參數來指定 SDDL 字串代表登錄安全性描述元。

範例 3:使用 ConvertFrom-SddlString 搭配和不使用 '-Type' 參數,將登錄訪問許可權 SDDL 轉換為 PSCustomObject

$acl = Get-Acl -Path HKLM:\SOFTWARE\Microsoft\

ConvertFrom-SddlString -Sddl $acl.Sddl | Foreach-Object {$_.DiscretionaryAcl[0]}

BUILTIN\Administrators: AccessAllowed (ChangePermissions, CreateDirectories, Delete, ExecuteKey, FullControl, GenericExecute, GenericWrite, ListDirectory, ReadExtendedAttributes, ReadPermissions, TakeOwnership, Traverse, WriteData, WriteExtendedAttributes, WriteKey)

ConvertFrom-SddlString -Sddl $acl.Sddl -Type RegistryRights | Foreach-Object {$_.DiscretionaryAcl[0]}

BUILTIN\Administrators: AccessAllowed (ChangePermissions, CreateLink, CreateSubKey, Delete, EnumerateSubKeys, ExecuteKey, FullControl, GenericExecute, GenericWrite, Notify, QueryValues, ReadPermissions, SetValue, TakeOwnership, WriteKey)

第一個命令會 Get-Acl 使用 Cmdlet 來取得 HKLM:\SOFTWARE\Microsoft\ 金鑰的安全性描述元,並將它儲存在變數中。

第二個命令會 ConvertFrom-SddlString 使用 Cmdlet 來取得 SDDL 字串串的文字表示法,該字串包含在代表安全性描述元之 物件的 Sddl 屬性中。

它不會使用 -Type 參數,因此顯示的訪問許可權適用於檔案系統。

第三個命令會 ConvertFrom-SddlString 使用 Cmdlet 搭配 -Type 參數,因此傳回的訪問許可權適用於登錄。

範例 4:將 Active Directory 訪問許可權 SDDL 轉換為 PSCustomObject

$user = [ADSI]"LDAP://CN=username,CN=Users,DC=domain,DC=com"
ConvertFrom-SddlString $user.psbase.ObjectSecurity.Sddl -Type ActiveDirectoryRights

第一個命令會使用 Active Directory 服務介面 (ADSI) 來取得用戶物件,並將它儲存在 變數中。

第二個命令會 ConvertFrom-SddlString 使用 Cmdlet 來取得 SDDL 字串串的文字表示法,該字串包含在代表安全性描述元之 物件的 Sddl 屬性中。

它會使用 -Type 參數來指定 SDDL 字串代表 Active Directory 安全性描述元。

參數

-Sddl

指定字串,表示 SDDL 語法中的安全性描述元。

類型:String
Position:0
預設值:None
必要:True
接受管線輸入:True
接受萬用字元:False

-Type

指定 SDDL 字串所代表的許可權類型。

此參數可接受的值為:

  • FileSystemRights
  • RegistryRights
  • ActiveDirectoryRights
  • MutexRights
  • SemaphoreRights
  • CryptoKeyRights
  • EventWaitHandleRights

根據預設,Cmdlet 會使用文件系統許可權。

PowerShell v6 和更新版本中不支援 CryptoKeyRightsActiveDirectoryRights

類型:Object
接受的值:FileSystemRights, RegistryRights, ActiveDirectoryRights, MutexRights, SemaphoreRights, CryptoKeyRights, EventWaitHandleRights
Position:Named
預設值:None
必要:False
接受管線輸入:False
接受萬用字元:False

輸入

String

您可以使用管線將 SDDL 字串傳送至此 Cmdlet。