powershell - 使用 PowerShell 对大量文件设置文件权限
问题描述
我有两个文件,一个包含安全组列表,另一个包含相应的文件夹路径。我需要做的就是遍历这些文件并将正确的安全组递归 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
:
安全组1 安全组2 安全组 3 安全组4 安全组5 安全组6 安全组7 安全组8 安全组9 安全组10
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
添加到project1
, securitygroup2
添加到project2
等。
解决方案
将两个文件读入变量,然后使用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
}
推荐阅读
- string - “1”和1是一回事吗?
- ansible - 如何将此输出解析为 Json 格式
- imagemagick - 防止黑白图像自动转换为灰度图像
- django - 如何在 django 的 models.py 中使用自定义验证器验证 DateTimeField?
- optimization - 功能程序是否已经采用 SSA 形式?
- python - 如何打乱数组的列?
- arrays - 对齐多个有序序列的最有效算法
- machine-learning - 使用 librosa.effects.trim 去除音频中的无声部分
- powershell - 进行多次 api 调用,并将每次调用的数据保存为 csv 格式的变量
- c++ - 在派生类中调用基类构造函数时出现分段错误