小知识:Linux文件和文件夹权限操作方法

linux 文件权限

首先来查看一下当前目录下的文件内容吧

ls -l    查看当前目录下的文件列表

ls -l xxx.xxx (xxx.xxx是文件名) 查看指定的文件

%小知识:Linux文件和文件夹权限操作方法-猿站网-插图

我们可以看到文件的权限,-rw-rw-r–  ,一共有10位数。

其中: 最前面那个 – 代表的是类型(详细如下面贴图所示)

中间那三个 rw- 代表的是所有者(user) 然后那三个 rw- 代表的是组群(group) 最后那三个 r– 代表的是其他人(other)

然后我再解释一下后面那9位数:

r 表示文件可以被读(read) w 表示文件可以被写(write) x 表示文件可以被执行(如果它是程序的话)

– 表示相应的权限还没有被授予

文件和文件夹操作权限:

权限 简写 对普通文件的作用 对文件夹的作用 读取 r 查看文件内容 列出文件夹中的文件(ls) 写入 w 修改文件内容 在文件夹中删除、添加或重命名文件(夹) 执行 x 文件可以作为程序执行 cd 到文件夹

%小知识:Linux文件和文件夹权限操作方法-1猿站网-插图

%小知识:Linux文件和文件夹权限操作方法-2猿站网-插图

需要注意的一点是,一个目录同时具有读权限和执行权限才可以打开并查看内部文件,而一个目录要有写权限才允许在其中创建其它文件,这是因为目录文件实际保存着该目录里面的文件的列表等信息。

补充:

特殊权限suid、sgid、sticky

在 linux 系统中还有三种与用户身份无关的三个文件权限属性。即suid、sgid和sticky。

suid(set user id, 4):

该属性只对有执行权限的文件有效,对目录无效。执行具有suid权限的程序时,引发的进程的所有者是程序文件的所有者,而不是启动程序的用户(除非二者是同一个人)。比如,如果一个程序的所有者是root且具有suid属性,一个普通用户执行此程序时,如同root执行此程序一样。(请注意该属性对shell脚本程序无效)该属性为一些特殊程序(如lpr)的启动带来了方便。但有时也带来了安全隐患:比如一个具有suid属性的程序如果在执行时运行了一个shell,那么用户可以籍此得到系统的最高权限。suid可用s表示,如:
?
1
2
$ ls -l /usr/bin/passwd
-rwsr-xr-x 1 root root 47032 feb 16 2014 /usr/bin/passwd

sgid(set group id, 4):

对于可执行文件,sgid与suid类似,引发的进程的所有组是程序文件所属的组。对于目录,sgid属性会使目录中新建文件的所属组与该目录相同。sgid也可以用s表示,如:
?
1
2
3
$ ls -l /var
drwxrwsr-x 2 root staff  4096 apr 10 2014 local
drwxrwxr-x 15 root syslog  4096 apr 4 19:57 log

sticky, 1:

仅对目录有效。带sticky属性的目录下的文件或目录可以被其拥有者删除或改名。常利用sticky属性创建这样的目录:组用户可以在此目录中创建新文件、修改文件内容,但只有文件所有者才能对自己的文件进行删除或改名。如系统中的/tmp文件夹。在属性字符串中,通常用t表示。
?
1
2
$ ls -l /
drwxrwxrwt  8 root root 4096 apr 4 23:57 tmp

改文件和文件夹对应用户的操作权限

如果你有一个自己的文件不想被其他用户读、写、执行,那么就需要对文件的权限做修改,这里有两种方式:

方式一:二进制数字表示

%小知识:Linux文件和文件夹权限操作方法-3猿站网-插图

每个文件的三组权限:

u 代表所有者(user) g 代表所有者所在的组群(group) o 代表其他人,但不是u和g (other) a 代表全部的人,也就是包括u,g和o 根据上图,其中:rwx也可以用数字来代替 r ————4 w ———–2 x ————1 – ————0

当大家都明白了上面的东西之后,那么我们常见的以下的一些权限就很容易都明白了:

-rw——- (600) 只有所有者才有读和写的权限 -rw-r–r– (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限 -rwx—— (700) 只有所有者才有读,写,执行的权限 -rwxr-xr-x (755) 只有所有者才有读,写,执行的权限,组群和其他人只有读和执行的权限 -rwx–x–x (711) 只有所有者才有读,写,执行的权限,组群和其他人只有执行的权限 -rw-rw-rw- (666) 每个人都有读写的权限 -rwxrwxrwx (777) 每个人都有读写和执行的权限

上实际操作

查看了test的权限,是所有者拥有读、写、执行的权限:

%小知识:Linux文件和文件夹权限操作方法-4猿站网-插图

然后向文件里添加了些内容,更改了下权限(700:-rwx——),并尝试在shiyanlou(所有者)下读取文件,可以读取。

%小知识:Linux文件和文件夹权限操作方法-5猿站网-插图

更换到其他用户peter,如下图再尝试读取,显示是权限不够,无法读取。

%小知识:Linux文件和文件夹权限操作方法-6猿站网-插图

方式二:加减赋值操作

u 代表所有者(user) g 代表所有者所在的组群(group) o 代表其他人,但不是u和g (other)

a 代表全部的人,也就是包括u,g和o

+ 和 – 分别表示增加和去掉相应的权限。+号一般不显示(初学练手时我还是会加上)

在终端输入:

chmod o+w xxx.xxx

chmod o w xxx.xxx         表示给其他人授予写xxx.xxx这个文件的权限

chmod go-rw xxx.xxx      表示删除xxx.xxx中组群和其他人的读和写的权限

chmod ug-r xxx.xxx

%小知识:Linux文件和文件夹权限操作方法-7猿站网-插图

%小知识:Linux文件和文件夹权限操作方法-8猿站网-插图

修改文件或文件夹的拥有者/所属的组

使用命令chown改变目录或文件的所有权(所有者/组)

注释:这里说的断断续续的,将在学习下一个内容(用户/组 增删改查)之后补充

文件与目录不仅可以改变权限,其所有权及所属用户组也能修改,和设置权限类似,用户可以通过图形界面来设置,或执行chown命令来修改。

我们先执行ls -l看看目录情况:

%小知识:Linux文件和文件夹权限操作方法-9猿站网-插图

可以看到test文件的所属用户组为root,所有者为root。

执行下面命令,把上图中test文件的所有权转移到用户peter:

# chown peter test

%小知识:Linux文件和文件夹权限操作方法-10猿站网-插图

要改变所属组,将test文件从root组中转移到组peter中,可使用下面命令:

# chown :peter test

%小知识:Linux文件和文件夹权限操作方法-11猿站网-插图

将所属的用户和组一起更改

将文件夹或文件test的拥有者修改成shiyanlou,所属的组修改成shiyanlou,如下图:

%小知识:Linux文件和文件夹权限操作方法-12猿站网-插图

以上所述是小编给大家介绍的linux文件和文件夹权限操作方法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:https://blog.csdn.net/zbj18314469395/article/details/79884857

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:解决Linux下Mysql5.7忘记密码问题

2023-3-16 8:34:39

建站知识

小知识:在APACHE环境下配置下载服务器的注意事项

2023-3-16 9:56:09

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索