chmod(1) - 改变文件或目录的权限
通过符号组合的方式更改目标文件或目录的权限
通过八进制数的方式更改目标文件或目录的权限
通过参考文件的权限来更改目标文件或目录的权限
chmod [OPTION]... MODE[,MODE]... FILE...
chmod [OPTION]... OCTAL-MODE FILE...
chmod [OPTION]... --reference=RFILE FILE...本手册页记录了 chmod 的 GNU 版本. chmod 根据 MODE 更改每个给定文件的文件权限, MODE 可以是所做更改的符号表示,也可以是表示新权限的八进制数值
符号模式的格式是 [ugoa...][[-+=][perms...]...] ,其中 perms 要么是 rwxXst 中的零个或多个字母,要么是 ugo 中的一个字母。可以给出多种符号模式,使用逗号分隔。
字母 ugoa 的组合控制了会对哪些用户对文件的访问权限进行更改
u: 拥有该文件的用户g: 文件组中的其他用户o: 文件组中不属于该文件组的其他用户(o)a: 或者所有用户
如果都没有给出,效果就像给出了 a ,但在 umask 中设置的数值位不受影响
操作符 + 导致所选文件模式位被添加到每个文件的现有文件模式位中; - 会移除; = 将添加它们并删除未提及的 MODE ,然而目录的未提及的固定的用户和用户组ID不受影响
操作符 + 使得用户选择的权限被追加到每个指定文件(操作给指定文件添加所选权限);操作符 - 使得这些权限被撤消; = 使得 指定文件只具有这些权限。
字符串 rwxXst 给用户设置新的属性:
- (
r)读权限 - (
w)写权限 - (
x)执行权(或对目录的访问权) - (
X)只有目标文件对某些用户是可执行的或该目标文件是目录时才追加x属性, - (
s) 同时设定用户或组ID - (
t)粘滞位(保存程序的文本到交换设备上)
除了这些标识之外, 你可以更加详细的和 ugo 组合设定更多权限
- (
u)目标文件所属用户 - (
g)目标文件用户所在的组 - (
o)其他用户
如果设置了目录的粘滞位, 那么只有文件和目录的所有者可以删除该目录下的文件。 (一般使用于类似于/tmp这样有基本写权限的目录)
数字模式是一到4个八进制数,每个数由位权为4,2,1的3位叠加而得. 被省略掉的数字缺省设置为零. 第一位为4时为suid,2时为sgid,1时为粘滞位,第二位设置文件所有者的权限:可读(4),可写(2),可执行(1); 第三位设置了文件所在组其他用户的权限,值如上;第四位设置了其 他组的用户的权限,值同上.
由于 chmod 的系统调用不支持, chomd 命令不能改变符号链接的权限. 由于符号链接的权限从不使用, 所以这也不成问题. 无论如何, 由于每个符号连接都可在命令行中列出, chmod 改变了所指文件的属性. 相反, chmod 在递归目录遍历时忽略所碰到的符号连接.
SETUID 位 和 SETGID 位
如果文件的组ID不匹配用户的有效组ID或用户的一个补充组ID,除非用户有适当的权限, 否则的话 chmod 会清除 set-group-id 位, 额外的限制可能会导致MODE 或 RFILE 的 set-user-id 和 set-group-id 位被忽略。这种行为取决于底层 chmod 系统调用的策略和功能。如果有疑问,请检查底层系统行为
对于目录,chmod 保留 set-user-id 和 set-group-id 位,除非另有明确指定。你可以设置或清除位的符号模式,如 u+s 和 g-s。要清除具有数值模式的目录的这些位,需要一个额外的前导零 ( 00755 ) ,或前导 = ( =755 )
限制删除或粘滞位
The restricted deletion flag or sticky bit is a single bit, whose interpretation depends on the file type. For directories, it prevents unprivileged users from removing or renaming a file in the directory unless they own the file or the directory; this is called the restricted deletion flag for the directory, and is commonly found on world-writable directories like /tmp. For regular files on some older systems, the bit saves the program’s text image on the swap device so it will load more quickly when run; this is called the sticky bit.
选项
更改文件的所有者或组未 OWNER 或 GROUP , 使用 --reference ,将目标文件的的组/所有者关系更改为引用文件的组/所有者
-c, --changes
效果类似于 -v , 仅仅当修改发生时候才汇报
-f, --silent, --quiet
不显示错误信息
-v, --verbose
为处理的每个文件输出完整信息
--no-preserve-root
不对根目录 / 进行特殊处理(默认)
--preserve-root
当执行目录为根目录时候, 则会失败
--reference=RFILE
使用 RFILE 的所有者和组, 而不是指定的 OWNER:GROUP 的值
-R, --recursive
递归执行文件和目录
--help
输出帮助信息并退出
--version
输出版本信息并退出
MODE 的形式如下 :
[ugoa]*([-+=]([rwxXst]*|[ugo]))+|[-+=][0-7]+
返回值
返回状态为成功除非给出了非法选项或非法参数。
例子
参考man chmod文档的DESCRIPTION段落得知:
u符号代表当前用户g符号代表和当前用户在同一个组的用户,以下简称组用户。o符号代表其他用户。a符号代表所有用户。r符号代表读权限以及八进制数4。w符号代表写权限以及八进制数2。x符号代表执行权限以及八进制数1。X符号代表如果目标文件是可执行文件或目录,可给其设置可执行权限。s符号代表设置权限suid和sgid,使用权限组合u+s设定文件的用户的ID位,g+s设置组用户ID位t符号代表只有目录或文件的所有者才可以删除目录下的文件。+符号代表添加目标用户相应的权限。-符号代表删除目标用户相应的权限。=符号代表添加目标用户相应的权限,删除未提到的权限。
linux文件的用户权限说明:
# 查看当前目录(包含隐藏文件)的长格式。
ls -la
-rw-r--r-- 1 user staff 651 Oct 12 12:53 .gitmodules
# 第1位如果是d则代表目录,是-则代表普通文件。
# 更多详情请参阅info coreutils 'ls invocation'(ls命令的info文档)的'-l'选项部分。
# 第2到4位代表当前用户的权限。
# 第5到7位代表组用户的权限。
# 第8到10位代表其他用户的权限。# 添加组用户的写权限。
chmod g+w ./test.log
# 删除其他用户的所有权限。
chmod o= ./test.log
# 使得所有用户都没有写权限。
chmod a-w ./test.log
# 当前用户具有所有权限,组用户有读写权限,其他用户只有读权限。
chmod u=rwx, g=rw, o=r ./test.log
# 等价的八进制数表示:
chmod 754 ./test.log
# 将目录以及目录下的文件都设置为所有用户拥有读写权限。
# 注意,使用'-R'选项一定要保留当前用户的执行和读取权限,否则会报错!
chmod -R a=rw ./testdir/
# 根据其他文件的权限设置文件权限。
chmod --reference=./1.log ./test.log注意
- 该命令是
GNU coreutils包中的命令,相关的帮助信息请查看man chmod或info coreutils 'chmod invocation'。 - 符号连接的权限无法变更,如果用户对符号连接修改权限,其改变会作用在被连接的原始文件。
- 使用
R选项一定要保留当前用户的执行和读取权限,否则会报错!
补充
文章的地址 : https://blog.xuite.net/wenhao.kk/note/143723399-Permission
以数字方式更改权限 chmod (数字权限) (档名)
其它更改权限方式 chmod (u, g, o, a)(+, -, =)(r, w, x) (档名) <不同括号内的值可以交替使用>
一般建立资料夹的预设权限为 777,而档案的权限为 666,因为受到 umask 预设值为 022 的影响, 所以建立出来的资料夹和档案权限才会有所不同,而系统的 umask 预设值在 /etc/profile 这个档案内, 我们可以依需求去做设定更改。
SUID(4)
chmod u+s (档名) <将档案给予SUID权限,任何人执行时身分会变成档案所有人>
chmod u-s (档名) <移除档案的SUID权限>
SGID(2)
chmod g+s (资料夹) <将资料夹给予SGID权限,任何人在此资料夹内建立档案,均会继承该目录的群组>
chmod g-s (资料夹) <移除资料夹的SGID权限>
sticky bit(1)
chmod o+t (档案) <将档案或资料夹给予sticky bit权限,不管权限为何,均不可删除他人的档案>
chmod o-t (档案) <移除档案或资料夹的sticky bit权限>权限的表示方式,若以数字完整的表示应该为四位数
第一位表示 特殊权限
第二位表示 拥有者(user)
第三位表示 群组(group)
第四位表示 其它(other)

此例可以明显看出特殊权限存在时,原本的栏位若有 x,则 s 或 t 就会呈现小写,若原本的栏位无 x,则 S 或 T 就会呈现大写,以此加以辨别
