Cacls和ICacls

Cacls和ICacls解释 Cacls 显示或修改文件的访问控制列表 ACL ICACLS 显示或修改自由访问控制表 Dacl 上指定的文件 并指定目录中的文件应用于存储的 Dacl 总结 显示或修改文件访问控制权限相关术语 一个 DACL Discretionar 其指出了允许和拒绝某用户或用户组的存取控制列表 当一个进程需要

解释: 

  Cacls:显示或修改文件的访问控制列表(ACL)

  ICACLS:显示或修改自由访问控制表(Dacl) 上指定的文件,并指定目录中的文件应用于存储的 Dacl。

  总结:显示或修改文件访问控制权限

相关术语:

  一个DACL(Discretionary Access Control List),其指出了允许和拒绝某用户或用户组的存取控制列表,当一个进程需要访问安全对象系统就会检查DACL来决定进程的访问权。如果一个对象没有DACL,则说明任何人对这个对象都可以拥有完全的访问权限。

  一个SACL(System Acess Control List),其指出了在该对象上的一组存取方式(如:读,谢,运行等)的存取控制权限细节的列表

  DACLSACL构成了整个存取控制列表Access Control List,简称ACL,ACL中的每一项我们叫做ACE(Acess Control Entry)

    以上是对DACL,SACL,ACL,ACE等相关术语的简要介绍。


 

 Cacls使用格式:
  Cacls 文件名 [/T] [/E] [/C] [/G user:perm] [/R user […]] [/P user:perm […]] [/D user […]]
  Filename——显示访问控制列表(以下简称ACL);
  /T——更改当前目录及其所有子目录中指定文件的 ACL;
  /E—— 编辑 ACL 而不替换;
  /C——在出现拒绝访问错误时继续;
  /G user:perm——赋予指定用户访问权限。Perm 可以是R(读取)、W(写入)、C(更改,写入)、F (完全控制);





  /R user——撤销指定用户的访问权限(仅在与 /E 一起使用);
  /P user:perm——替换指定用户的访问权限;

  /D user——拒绝指定用户的访问

 

实例:以Windows系统为例

  1.查看目录和ACL
  在E:\>提示符下输入“Cacls 文件名”命令,接着就会列出Windows系统中用户组和用户对文件名目录的访问控制权限项目。如果想查看CCE目录中所有文件访问控制权限,输入“Cacls 文件名\?.?”命令即可。

  替换用户访问权限:将本机用户user的完全控制权限替换为只读权限。在命令提示符对话框中输入“ Cacls file /t /e /c /p user:r ”命令即可。

  撤销用户访问权限:要想撤销本机用户user对该目录的完全控制权限也很容易,在命令提示符中运行“Cacls file /t /e /c /r user ”即可。

  拒绝用户访问:要想拒绝用户user访问file目录及其所有子目录中的文件,运行“Cacls file /t /e /c /d user”即可。

 

  某病毒调用calcs命令例子如下:

  病毒进程: c:\documents andsettings\administrator\local settings\temp\tp5.tmp

  行为:创建新进程

  目标: c:\windows\system32\cacls.exe

  命令行: cacls.exeC:\WINDOWS\system32\cmd.exe /e /t /g everyone:F

    意思就是给everyone用户组(所有人)cmd.exe的完全控制


 

 

ICacls使用格式:(下列参数详见表格)

Cacls和ICacls

 

 

  ICacls 文件名 /save Tofile [/T] [/C] [/L] [/Q]:将匹配名称的文件的DACL存储到Tofile中,以便将来与 /restore一起使用。

  ICacls directory [/substitute SidOld SidNew […]] /restore Tofile:将存储的DACL应用于目录中的文件。

  ICacls 文件名 /reset [/T] [/G] [/L] [/Q]:更改所有匹配名称的所有者,该选项不会强制更改所有身份,使用takeown.exe实用程序可实现该目的。

  ICacls 文件名 /findsid Sid [/T] [/C] [/L] [/Q]:查找包含显式SID的ACL的所有匹配名称。

  ICacls 文件名 /verify [/T] [/C] [/L] [/Q]:查找其ACL不规范或长度与ACE计数不一致的所有文件

  ICacls 文件名 /reset [/T] [/C] [/L] [/Q]:为所有匹配文件使用默认继承的ACL替换ACL

  ICACLS 文件名 [/grant[:r] Sid:perm[…]]
       [/deny Sid:perm […]]
       [/remove[:g|:d]] Sid[…]] [/T] [/C] [/L]
       [/setintegritylevel Level:policy[…]]


     /grant[:r] Sid:perm 授予指定的用户访问权限。如果使用 :r,

 

    /deny Sid:perm 显式拒绝指定的用户访问权限。
        将为列出的权限添加显式拒绝 ACE,
        并删除所有显式授予的权限中的相同权限。

 

    /remove[:[g|d]] Sid 删除 ACL 中所有出现的 SID。使用
        :g,将删除授予该 SID 的所有权限。使用
        :d,将删除拒绝该 SID 的所有权限。

 

    /setintegritylevel [(CI)(OI)] 级别将完整性 ACE 显式添加到所有
        匹配文件。要指定的级别为以下级别之一:
            L[ow]
            M[edium]
            H[igh]
        完整性 ACE 的继承选项可以优先于级别,但只应用于
        目录。





 

    /inheritance:e|d|r
        e – 启用继承
        d – 禁用继承并复制 ACE
        r – 删除所有继承的 ACE


注意:Sid 可以采用数字格式或友好的名称格式。如果给定数字格式,那么请在 SID 的开头添加一个 *。 

  /T 指示在以该名称指定的目录下的所有匹配文件/目录上执行此操作。

     /C 指示此操作将在所有文件错误上继续进行。仍将显示错误消息。

     /L 指示此操作在符号链接本身而不是其目标上执行。

     /Q 指示 icacls 应该禁止显示成功消息。

 

   

  

示例:

 

 

 

 

 

1、强制将当前目录下的所有文件及文件夹、子文件夹下的所有者更改为管理员组(administrators)命令:

takeown /f * /a /r /d y

2、将所有d:\documents目录下的文件、子文件夹的NTFS权限修改为仅管理员组(administrators)完全控制(删除原有所有NTFS权限设置):

cacls d:\documents\*.* /T /G administrators:F

3、在原有d:\documents目录下的文件、子文件夹的NTFS权限上添加管理员组(administrators)完全控制权限(并不删除原有所有NTFS权限设置):

cacls d:\documents\*.* /T /E /G administrators:F

4、取消管理员组(administrators)完全控制权限(并不删除原有所有NTFS权限设置):

 

转载于:https://www.cnblogs.com/Aley/p/11089538.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/201568.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月20日 上午9:06
下一篇 2026年3月20日 上午9:06


相关推荐

  • 完美解决IDEA全局搜索快捷键失效的问题

    完美解决IDEA全局搜索快捷键失效的问题前言在使用 IDEA 开发工具时 全局搜索快捷键 Ctrl Shift F 经常使用到 但是偶尔会有快捷键失效 无法使用的情况 如何解决呢 原因经排查发现 之所以全局搜索快捷键失效 是因为电脑中其他程序的快捷键与 IDEA 全局搜索快捷键冲突导致的 解决将搜狗输入法中冲突的快捷键勾选取消即可

    2026年3月26日
    2
  • 拜拜了SWE-Bench!Cursor刚发了个AI Coding评测基准,难哭Claude

    拜拜了SWE-Bench!Cursor刚发了个AI Coding评测基准,难哭Claude

    2026年3月14日
    2
  • 结构体字节对齐

    结构体字节对齐先说个题外话 早些年我学 C 程序设计时 写过一段解释硬盘 MBR 分区表的代码 对着磁盘编辑器怎么看 怎么对 可一执行 结果就错了 当时调试也不太会 又根本没听过结构体对齐这一说 所以 问题解决不了 好几天都十分纠结 后来万般无奈请教一个朋友 才获悉可能是结构体对齐的事 一查 一改 果真如此 nbsp nbsp 问题是解决了 可网上的资料多数只提到内存对齐是如何做

    2026年3月17日
    2
  • origin带误差线的柱状图_怎么加误差棒

    origin带误差线的柱状图_怎么加误差棒软件版本:OriginPro2021b(64-bit)SR29.8.5.212(学习版)本期目标:接下来,正文开始:1,如图1,数据包含三个类型的数据列(X轴/Y轴/误差列)。A列表示X轴分组,B/D/F/H列表示Y轴数据,C/E/G/I列表示误差数据(此处为标准差)。注:此处数据设置为关键,需要按照正确,后面才可以绘制带有误差棒的分组柱状图。图1数据设置2,按照上图方式输入数据后,选中数据后,点击菜单栏——绘图——类别——多因子组柱状图-索引数据进行图形绘制,如图

    2022年9月29日
    5
  • iBatis和 MyBatis的区别

    iBatis和 MyBatis的区别本文主要讲述了 iBatis2 x 和 MyBatis3 0 x 的区别 以及从 iBatis 向 MyBatis 移植时需要注意的地方 通过对本文的学习 读者基本能够了解 MyBatis 有哪些方面的改进 并能够顺利使用 MyBatis 进行开发 本文更适合有 iBatis 基础的开发人员阅读 从 iBatis 到 MyBatis 你准备好了吗 对于从事 Jav

    2026年3月17日
    3
  • python中的变量命名规则

    python中的变量命名规则ThereareonlytwohardthingsinComputerScience:cacheinvalidationandnamingthings.在计算机科学领域只有两件难事:缓存失效和给东西起名字变量用的好或不好,和代码质量有着非常重要的联系,合理的使用变量,可以让你的代码可读性更高并且更加简洁。python中的变量命名规则1.变量命名2.变量命名的描述性3.变量名尽量短,但是不要太短4.合理使用变量5.变量定义尽量靠近使用6.合理使用namedtuple/

    2022年5月31日
    53

发表回复

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

关注全栈程序员社区公众号