给用户赋某个文件夹操作的权限

在root用户登录的情况,赋予opt目录给liuhai这个用户权限 示例代码:

# 将目录/opt 及其下面的所有文件、子目录的文件主改成 lingdu
chown -R lingdu:lingdu /opt 

然后在lingdu用户下:

#给目录opt设置权限
chmod 760 /opt
or 
chmod 775 /opt

chown 命令

  • 语法
chown(选项)(参数)
  • 选项
-c或——changes:效果类似“-v”参数,但仅回报更改的部分;

-f或--quite或——silent:不显示错误信息;

-h或--no-dereference:只对符号连接的文件作修改,而不更改其他任何相关文件;

-R或——recursive:递归处理,将指定目录下的所有文件及子目录一并处理;

-v或——version:显示指令执行过程;

--dereference:效果和“-h”参数相同;

--help:在线帮助;

--reference=<参考文件或目录>:把指定文件或目录的拥有者与所属群组全部设成和参考文件或目录的拥有者与所属群组相同;

--version:显示版本信息。
  • 参数
用户:组:指定所有者和所属工作组。当省略“:组”,仅改变文件所有者;
文件:指定要改变所有者和工作组的文件列表。支持多个文件和目标,支持shell通配符。
  • 实例
# 将目录/opt 及其下面的所有文件、子目录的文件主改成 lingdu
chown -R lingdu:lingdu /opt 

chmod命令

Linux/Unix 的文件调用权限分为三级 : 文件拥有者、群组、其他。利用 chmod 可以藉以控制文件如何被他人所调用。

使用权限 : 所有使用者

  • 语法
chmod [-cfvR] [--help] [--version] mode file...
  • 参数说明

mode : 权限设定字串,格式如下 :

[ugoa...][[+-=][rwxX]...][,...]

其中:

  1. u 表示该文件的拥有者,g 表示与该文件的拥有者属于同一个群体(group)者,o 表示其他以外的人,a 表示这三者皆是。
  2. '+' 表示增加权限、'-' 表示取消权限、'=' 表示唯一设定权限。
  3. r 表示可读取,w 表示可写入,x 表示可执行,X 表示只有当该文件是个子目录或者该文件已经被设定过为可执行。

其他参数说明:

  1. -c : 若该文件权限确实已经更改,才显示其更改动作
  2. -f : 若该文件权限无法被更改也不要显示错误讯息
  3. -v : 显示权限变更的详细资料
  4. -R : 对目前目录下的所有文件与子目录进行相同的权限变更(即以递回的方式逐个变更)
  5. --help : 显示辅助说明
  6. --version : 显示版本
  • 实例

将文件 file1.txt 设为所有人皆可读取 :

chmod ugo+r file1.txt

将文件 file1.txt 设为所有人皆可读取 :

chmod a+r file1.txt

将文件 file1.txt 与 file2.txt 设为该文件拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 :

chmod ug+w,o-w file1.txt file2.txt

将 ex1.py 设定为只有该文件拥有者可以执行 :

chmod u+x ex1.py

将目前目录下的所有文件与子目录皆设为任何人可读取 :

chmod -R a+r *

此外chmod也可以用数字来表示权限如 :

chmod 777 file

语法为:

chmod abc file

其中a,b,c各为一个数字,分别表示User、Group、及Other的权限。 r=4,w=2,x=1 若要rwx属性则4+2+1=7; 若要rw-属性则4+2=6; 若要r-x属性则4+1=5。

chmod a=rwx filechmod 777 file 效果相同


chmod ug=rwx,o=x filechmod 771 file 效果相同

若用chmod 4755 filename可使此程序具有root的权限