使用PowerShell为大量文件设置文件权限

问题描述 投票:0回答:1

我有两个文件,一个包含安全组列表,另一个包含相应的文件夹路径。我需要做的就是遍历这些文件并将正确的安全组递归RW访问应用到正确的文件夹。

因此第1行的安全组将应用于第1行的文件夹。

Powershell脚本:

foreach ($group in gc c:\temp\securitygroups.txt) {
    $rule = New-Object System.Security.AccessControl.FileSystemAccessRule ($group, 'Modify','ContainerInherit,ObjectInherit', 'None', 'Allow')

    foreach ($folder in gc c:\temp\folders.txt) {
        $acl = Get-Acl $folder
        $acl.SetAccessRule($rule)
        Set-Acl $folder $acl
    }
}

securitygroups.txt

securitygroup1
securitygroup2
securitygroup3
securitygroup4
securitygroup5
securitygroup6
securitygroup7
securitygroup8
securitygroup9
securitygroup10

folders.txt

D:\shares\projects\project1
D:\shares\projects\project2
D:\shares\projects\project3
D:\shares\projects\project4
D:\shares\projects\project5
D:\shares\projects\project6
D:\shares\projects\project7
D:\shares\projects\project8
D:\shares\projects\project9
D:\shares\projects\project10

目前,securitygroups.txt中的每个安全组都被添加到列表中的每个文件夹中,这不是我想要的,我希望securitygroup1添加到project1securitygroup2添加到project2等。

powershell file-permissions windows-scripting
1个回答
0
投票

将两个文件读入变量,然后使用for循环同时迭代两个数组:

$groups  = Get-Content 'c:\temp\securitygroups.txt'
$folders = Get-Content 'c:\temp\folders.txt'

for ($i=0; $i -lt $folders.Count; $i++) {
    $rule = New-Object Security.AccessControl.FileSystemAccessRule ($groups[$i], 'Modify', 'ContainerInherit,ObjectInherit', 'None', 'Allow')
    $acl = Get-Acl $folders[$i]
    $acl.SetAccessRule($rule)
    Set-Acl $folders[$i] $acl
}

推荐问答