特定のレジストリ キーにアクセス許可を設定し、すべての子キーに同じアクセス許可を設定しようとしています。最初のキーのアクセス許可を設定することは問題ではありませんが、残りを機能させるには問題があります。
テスト目的で、HKLM\Software\1 とサブ フォルダー 2\3 を作成しました。
$REG = Get-Acl HKLM:\SOFTWARE\1
$Rule = New-Object System.Security.AccessControl.RegistryAccessRule ("Everyone","FullControl","Allow")
$REG.SetAccessRule($Rule)
$REG |Set-Acl -Path HKLM:\SOFTWARE\1
$Dir = Get-Childitem "HKLM:\SOFTWARE\1" -Recurse
foreach ($Folder in $Dir)
{
Write-Host $Folder
Set-Acl $Folder $Reg
}
Write-Host $Folder を実行すると、適切なサブキーが取得されますが、それを Set-ACL にプッシュすると、次のエラーが発生します。
Set-Acl : Cannot find path 'C:\Documents and Settings\USER\Desktop\HKEY_LOCAL_MACHINE\SOFTWARE\1\2\3' because it does not exist.
作業ソリューション:
$REG = Get-Acl HKLM:\SOFTWARE\1
$Rule = New-Object System.Security.AccessControl.RegistryAccessRule ("Everyone","FullControl","Allow")
$REG.SetAccessRule($Rule)
$REG |Set-Acl -Path HKLM:\SOFTWARE\1
$Dir = Get-Childitem "HKLM:\SOFTWARE\1" -Recurse
foreach ($Folder in $Dir)
{
$REG.SetAccessRule($Rule)
$Reg | Set-Acl $Folder.PSPath
}