当前位置: 移动技术网 > 科技>软件教程>新手入门 > Cmd下修改文件访问控制权限

Cmd下修改文件访问控制权限

2020年09月02日  | 移动技术网科技  | 我要评论
Cmd下修改文件访问控制权限保证自己的磁盘分区格式是NTFS.FAT32是不行的.一、Cacls.exe命令的使用这是一个在Windows 2000/XP/Server 2003操作系统下都可以使用的命令,作用是显示或者修改文件的访问控制... 09-08-01
保证自己的磁盘分区格式是ntfs.fat32是不行的.
一、cacls.exe命令的使用
这是一个在windows 2000/xp/server 2003操作系统下都可以使用的命令,作用是显示或者修改
文件的访问控制表,在命令中可以使用通配符指定多个文件,也可以在命令中指定多个用户。
命令语法如下:

cacls filename [/t] [/e] [/c] [/g usererm] [/r user [...]] [/p usererm [...]] [/d user [...]]

filename:显示访问控制列表(以下简称acl)

/t:更改当前目录及其所有子目录中指定文件的acl

/e:编辑acl而不替换

/c:在出现拒绝访问错误时继续   

/g userer:perm:赋予指定用户访问权限,perm代表不同级别的访问权限,其值可以是r(读取)、w(写入)、c(更改,写入)、f(完全控制)等。

/r user:撤销指定用户的访问权限,注意该参数仅在与“/e”一起使用时有效。

/p user:perm:替换指定用户的访问权限,perm的含义同前,但增加了“n(无)”的选项。

/d user:拒绝指定用户的访问。



①:查看文件夹的访问控制权限

查看c:\ruery文件夹的访问控制权限,那么只需要在"开始→运行"对话框或切换到命令提示符模式下,键入如下命令:
cacls c:\ruery

此时,我们会看到所有用户组和用户对c:\ruery文件夹的访问控制权限项目.
ci表示ace会由目录继承.
oi表示ace会由文件继承.
io表示aci不适用于当前文件或目录.
每行末尾的字母表示控制权限,例如"f"表示完全控制,"c"表示更改,"w"表示写入."r"表示读取

如果你希望查看该文件夹中所有文件(包括子文件夹中的文件)的访问控制权限(见图1),可以键入"cacls c:\ruery ."命令.



②:修改文件夹的访问控制权限

假如你希望给予本地用户ruery完全控制c:\ruery文件夹及子文件夹中所有文件的访问权限,只需要键入如下命令:
cacls c:\ruery /t /e /c /g ruery:f
"/t"表示修改文件夹及子文件夹中所有文件的acl.
"/e"表示仅做编辑工作而不替换.
"/c"表示在出现拒绝访问错误时继续.
"/g ruery:f"表示给予本地用户ruery以完全控制的权限.
"f"代表完全控制,如果只是希望给予读取权限,那么应当是"r"



③:撤销用户的访问控制权限

如果你希望撤销ruery用户对c:\ruery文件夹及其子文件夹的访问控制权限,可以键入如下命令:
cacls c:\ruery /t /e /c /r ruery

如果只是拒绝用户的访问,那么可以键入如下命令:
cacls c:\ruery /t /e /c /d ruery



cacls.exe c:\windows\system32\net.exe /c /e /t /g administrators:f
cacls.exe c:\windows\system32\dllcache\net.exe /c /e /t /g administrators:f

cacls.exe c:\windows\system32\net.exe /c /e /t /g everyone:f
cacls.exe c:\windows\system32\dllcache\net.exe /c /e /t /g everyone:f

cacls.exe c:\windows\system32\net.exe /c /e /t /g system:f
cacls.exe c:\windows\system32\dllcache\net.exe /c /e /t /g system:f

cacls.exe c:\windows\system32\net.exe /c /e /t /g administrator:f
cacls.exe c:\windows\system32\dllcache\net.exe /c /e /t /g administrator:f


cacls.exe c: /e /t /g everyone:f    #把d盘设置为everyone可以浏览
cacls.exe d: /e /t /g everyone:f    #把d盘设置为everyone可以浏览
cacls.exe e: /e /t /g everyone:f     #把e盘设置为everyone可以浏览
cacls.exe f: /e /t /g everyone:f     #把f盘设置为everyone可以浏览



二、使用增强工具xcals.exe

在windows 2000资源工具包中,微软还提供了一个名为xcacls.exe的文件控制权限修改工具,其功能较cacls.exe更为强大,可以通过命令行设置所有可以在windows资源管理器中访问到的文件系统安全选项,我们可以从[url]http: //www.microsoft.com/windows2000/techinfo/reskit/tools/existing/xcacls-o.asp [/url]下载,安装后即可使用。

xcacls.exe命令的语法和参数与cacls.exe基本相同,但不同的是它通过显示和修改件的访问控制列表(acl)执行此操作。在“/g”参数后除保持原有的perm权限外,还增加了spec(特殊访问权限)的选项,另外还增加了“/y”的参数,表示禁止在替换用户访问权限时出现确认提示,而默认情况下,cacls.exe是要求确认的,这样在批处理中调用cacls.exe命令时,程序将停止响应并等待输入正确的答案,引入“/y”参数后将可以取消此确认,这样我们就可以在批处理中使用xcacls.exe命令了。

①:查看文件或文件夹的权限

在“开始→运行”对话框或切换到命令提示符模式下,注意请事先将“c:\program files\resource kit”添加到“系统属性→高级→环境变量→系统变量”中,或者通过cd命令将其设置为当前路径,否则会提示找不到文件,然后键入如下命令:

xcacls c:\ruery


此时,我们会看到图2所示的窗口,这里可以查看到所有用户组或用户对c:\ruery文件夹的访问控制权限,io表示此ace不应用于当前对象,ci表示从属窗口将继承此ace,oi表示从属文件将继承该ace,np表示从属对象不继续传播继承的ace,而每行末尾的字母表示不同级别的权限,
f表示完全控制.
c表示更改.
w表示写入.


②:替换文件夹中的acl而不确认
xcacls c:\ruery /g administrator:rw/y
以上命令将替换c:\ruery文件夹中所有文件和文件夹的acl,而不扫描子文件夹,也不会要求用户确认.


③:赋予某用户对文件夹的控制权限
xcacls h:\temp /g administrator:rwed;rw /e

以上命令将赋予用户ruery对c:\ruery文件夹中所有新建文件的读取、写入、运行和删除权限,但需要说明的是,这条命令只是赋予了用户对文件夹本身的读写权限,而不包括子文件夹下的文件。

对普通用户来说,cals.exe和xcacls.exe的作用可能不是那么明显,这在windows 2000/xp/server 2003的无人值守安装中特别有用,管理员可以为操作系统所在的文件夹设置初始访问权限;在将软件分发到服务器或工作站时,还可以借助 xcacls.exe提供单步保护,以防止用户误删除文件夹或文件。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网