使用PowerShell管理文件访问权限

文件和目录的权限管理是一项复杂且耗时的工作,尤其是在Windows环境中,windows环境中,文件和目录权限管理使用图形化界面进行标准操作。但Powershell将能使这项工作更快更容易。

Powershell能够完成权限管理的哪些操作呢

  • 列出文件和目录权限设置
  • 添加文件和目录权限
  • 移除文件和目录权限
  • 修改文件和目录的属主
  • 启用和禁用目录的继承属性

列出NTFS文件和目录权限

PS C:\Windows\System32> [System.Enum]::GetNames([System.Security.AccessControl.FileSystemRights])

使用PowerShell管理文件访问权限

上述权限类型,在windows系统中,可大致分为两类

基本权限

  • Full Control:用户可以修改、添加、移动和删除文件和目录以及相应的属性,换而言之,用户可以改变所有文件以及子目录的权限设定。
  • Modify:用户可以修改文件和文件属性,包括删除或添加文件到目录或者删除、添加属性到文件
  • Read & Execute:用户可以运行可执行文件,包括脚本
  • Read:用户能够查看文件、文件属性和目录
  • Write:用户能够写入新数据到文件并能将文件添加到目录

高级权限

  • Traverse Folder/Execute File:允许用户即使没有文件和目录的权限,也允许其浏览文件夹。此外,也允许执行文件
  • List Folder/Read Data:允许列出文件以及子目录,并能够访问文件中包含的内容
  • Read Attributes:查看文件或目录的属性
  • Write Attributes:更改文件或目录的属性
  • Read Extended Attributes:查看文件或目录的扩展属性
  • Write Extended Attributes:更改文件或目录的扩展属性
  • Create Files/Write Data:允许在目录中创建文件并能更改目录中的文件(change)
  • Create Folders/Append Data:允许在当前目录中创建目录,允许追加数据到文件,但是不允许更改(change)、删除或者覆盖替换文件中的内容
  • Delete:允许删除文件或目录
  • Read Permissions:用户可以读取文件或目录的权限设置
  • Change Permission:用户可以更改(change) 文件或目录的权限设置
  • Take Ownership:用户可以取得文件或目录的所有权
  • Synchronize:使用文件或目录进行同步。(原文是Allows or denies different threads to wait on the handle for the file or folder and synchronize with another thread that may signal it. This permission applies only to multithreaded, multiprocessing programs.,不太理解,有大神知道的话,烦请告知,多谢)

检索文件或目录的权限设置

使用get-ACL来检索文件或目录的权限设置
Get-ACL -Path "Folder1"

使用PowerShell管理文件访问权限

默认输出不易读,可以使用下面的方式
(Get-ACL -Path "Folder1").Access | Format-Table IdentityReference,FileSystemRights,AccessControlType,IsInherited,InheritanceFlags -AutoSize

使用PowerShell管理文件访问权限

新建一个文件test1.txt,查看它的权限配置
(Get-ACL -Path "Test1.txt").Access | Format-Table IdentityReference,FileSystemRights,AccessControlType,IsInherited,InheritanceFlags -AutoSize

使用PowerShell管理文件访问权限

修改文件或目录的权限设置

使用powershell来修改文件或目录的权限,一般流程如下

  • 检索已存在的ACL规则
  • 创建需要应用的目标规则,FileSystemAccessRule语法结构类似:Identity String,FileSystemRights,AccessControlType
  • 添加新的ACL规则到已存在的规则集
  • 使用Set-ACL将前面新建的ACL规则应用到目标文件或目录
$ACL = Get-ACL -Path "Test1.txt"
$AccessRule = New-Object System.Security.AccessControl.FileSystemAccessRule("TestUser1","Read","Allow")
$ACL.SetAccessRule($AccessRule)
$ACL | Set-Acl -Path "Test1.txt"
(Get-ACL -Path "Test1.txt").Access | Format-Table IdentityReference,FileSystemRights,AccessControlType,IsInherited,InheritanceFlags -AutoSize
使用PowerShell管理文件访问权限

复制权限设置到新的对象上面

我们将文件test1上面的访问权限复制到文件Test2上

Get-ACL -Path "Test1.txt" | Set-ACL -Path "Test2.txt"
(Get-ACL -Path "Test2.txt").Access | Format-Table IdentityReference,FileSystemRights,AccessControlType,IsInherited,InheritanceFlags -AutoSize
使用PowerShell管理文件访问权限

移除文件或目录的访问权限

要移除文件或目录的某个访问权限,需要通过与修改权限同样的步骤,但是用的对象方法不一样(前者使用$ACL.SetAccessRule(),而后者使用$ACL.RemoveAccessRule()

$ACL = Get-ACL -Path "Test1.txt"
$AccessRule = New-Object System.Security.AccessControl.FileSystemAccessRule("TestUser1","Read","Allow")
$ACL.RemoveAccessRule($AccessRule)
$ACL | Set-Acl -Path "Test1.txt"
(Get-ACL -Path "Test1.txt").Access | Format-Table IdentityReference,FileSystemRights,AccessControlType,IsInherited,InheritanceFlags -AutoSize
使用PowerShell管理文件访问权限

修改继承和所有权属性

启用\禁用继承属性

要更改继承属性,我们不得不使用SetAccessRuleProtection方法,它包括两个参数,isProtected:定义是否禁用继承,可用值为(True\False),如果值为True意为禁用继承;`preserveInheritance`:定义在禁用继承时是否保留已继承的权限设置,可用值为(True$False),如果值为$True,将保留继承的权限

$ACL = Get-Acl -Path "Folder1"
$ACL.SetAccessRuleProtection($true,$false)
$ACL | Set-Acl -Path "Folder1"
使用PowerShell管理文件访问权限

有时上述操作可能需要管理员身份,不然会报如下错误:
Set-Acl: The process does not possess the 'SeSecurityPrivilege' privilege which is required for this operation.

修改所有权属性

修改所有权属性,需要定义一个用户账号对象,然后使用SetOwner()方法来完成

$ACL = Get-Acl -Path "Folder1"
$User = New-Object System.Security.Principal.Ntaccount("TestUser1")
$ACL.SetOwner($User)
$ACL | Set-Acl -Path "Folder1"
Get-ACL -Path "Folder1"
使用PowerShell管理文件访问权限

文章来源:https://www.cnaaa.net,转载请注明出处:https://www.cnaaa.net/archives/7788

(0)
郭靖的头像郭靖
上一篇 2023年3月27日 下午4:25
下一篇 2023年3月28日 下午5:22

相关推荐

  • Hyper-V虚拟机显卡虚拟化VGPU 配置指南V2.0

    ⚠️ 重要前提 🔧 配置脚本(管理员 PowerShell) 运行脚本(管理员权限) 脚本操作流程(交互式步骤) 步骤 操作 说明 1 输入虚拟机名称 输入您要配置的Hyper-V虚拟机名称(区分大小写) 2 确认关闭虚拟机 如果虚拟机正在运行,需要关闭才能继续 3 设置显存分配 输入推荐显存大小(GB),默认1GB 4 确认配置 查看配置参数并确认应用 5…

    2025年6月14日
    55000
  • tcping实用小工具

    一、tcping介绍tcping:tcping命令基于tcp协议监控,可以从较低级别的协议获得简单的,可能不可靠的数据报服务。 原则上,TCP应该能够在从容硬线连接到分组交换或电路交换网络的各种通信系统之上操作。 二、tcping与ping的区别(一).指代不同①ping:1、ping:是Windows、Unix和Linux系统下的一个命令。ping也属于一…

    2023年7月17日
    83700
  • IIS怎么设置应用程序池自动回收

    1、打开 IIS 管理控制台,双击“应用程序池”文件夹。 2、右击适当的应用程序池,然后单击“高级设置”。出现应用程序池的属性对话框。 3、默认回收是有一个固定时间间隔的,但是太长了 4、点击特定时间后面的三个点 5、然后点击添加按钮,接着在Value里面设置时间点,如下图所示 6、最后可以设置多个时间点,如下图所示

    2022年8月9日
    2.1K00
  • NtLmSsp攻击的解决办法

    问题描述 服务器无法连接或者服务器经常自动重启 问题排查 查看系统日志,在安全类目发现大量的登录审核失败的记录。 解决方法 进行NTLM策略控制,彻底阻止NTLM响应 修改以下2个设置: 网络安全:Lan管理器身份验证级别:仅发送 NTLMv2 响应/拒绝 LM 和 NTLM 网络安全:限制NTLM:传入NTLM流量 修改成拒绝所有账户

    2022年9月3日
    3.0K00
  • Win11如何执行干净启动?启动/禁用干净启动

      干净启动是什么?通过使用最少的一组驱动程序和启动程序来启动 Windows,这种启动方式就称为“ 干净启动”。使用干净启动过程启动计算机时,Microsoft Windows在启动时仅加载基本设备和服务。那Win11如何执行干净启动呢?下面我们就来看看。   如何执行 Windows 11 的干净启动   要执行 Windows 11 的干净启动,请执行…

    2024年6月14日
    1.1K00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

在线咨询: QQ交谈

邮件:712342017@qq.com

工作时间:周一至周五,8:30-17:30,节假日休息

关注微信