Linux文件权限

简介: Linux文件权限

文件权限

  1. chmod
  • 数字表示法
  • chmod 权限命令 文件
  • chmod -R 权限命令 文件夹
    加上 -R 表示递归的执行文件夹下面的所有文件。权限命令分为r:4,w:2:x:1"的组合。
    比如: -rwxrwxrwx 1 szz szz 560 Nov 29 03:16 wiat_.c 前面的权限 -rwxrwxrwx 就是表示777。
  • 字符表示法
  • chmod [用户类型] [+|-|=] [权限字符] 文件名
  • chmod -R [用户类型] [+|-|=] [权限字符] 文件夹
    比如:
$ chmod u+rw wait.c  # 给用户 读写权限
$ chmod u-rw wait.c  # 去掉用户的读写权限
$ chmod g+rw wait.c  # 给组 读写权限
$ chmod g=x wait.c   # 设置组具有执行权限
$ chmod a=x wait.c   # 都有执行权限
  • chown
  • chown [选项]... [所有者] [:组] 文件 ...
  • chown -R [所有者] [:组] 文件夹 ...
  • 比如:
$ ls -l wiat_.c 
---x-wxrwx 1 szz szz 560 Nov 29 03:16 wiat_.c
//修改用户
$ sudo chown root wiat_.c 
---xrw-rwx 1 root szz 560 Nov 29 03:16 wiat_.c
// 修改组
$ sudo chown .root wiat_.c 
---xrw-rwx 1 root root 560 Nov 29 03:16 wiat_.c
//同时修改
$ sudo chown szz.szz wiat_.c 
---xrw-rwx 1 szz szz 560 Nov 29 03:16 wiat_.c
  1. 增加/删除用户在指定的组里添加成员。
  • 增加组 : groupadd groupname
  • 增加用户: useradd username -g groupname
  • 删除用户: userdel username -g groupname
  • 查看 : id username
  • 改变用户: sudo su - username
  1. 对于一个文件操作假设当前环境是:
  • 用户有: lam, sz, other
  • 组别:family
    状态如下:lam, sz 属于同一个组 family
$ id lam
uid=1001(lam) gid=1002(family) groups=1002(family)
$ id sz
uid=1002(sz) gid=1002(family) groups=1002(family)
  1. 有文件:wait.cpp
$ ls -l wait.cpp 
---xrw-r-- 1 lam family 20 Nov 29 05:09 wait.cpp
  1. 权限解释:
  • user : 对于用户 lam 具有可执行权限(x)
  • gropu: 对于属于组family的成员都具有具有rw权限
  • other: 对于其他人other具有r权限
    要是想让不同的成员获得想要的权限,就可以使用 chowm 命令来改变。
  • 删除 :删除一个文件,是看该文件所属的目录权限
  1. 对于一个目录的操作目录Process: dr-x--x--- 2 lam family 4096 Nov 29 05:14 Process用户other目前对于Process/目录没有任何的执行能力。
$ cd Process/
-su: cd: Process/: Permission denied
$ ls Process/
ls: cannot open directory 'Process/': Permission denied
  1. Process/的权限改为dr-x--x--x可以执行cd, 再改为dr-x--xr-x可以执行ls Process/
  • 总结
  • 可读r: 表示具有浏览目录下面文件及目录的权限。即可用 ls
  • 可写w: 表示具有增加、删除或者修改目录内文件名的权限
  • 可执行x: 表示居于进入目录的权限,即 cd
  1. 默认权限文件权限计算方法与umask
  • 创建目录默认的最大权限是:777
  • 创建文件最大权限是:666
  • 创建目录时:用 777- umask 即可得到所得目录权限
  • 创建文件时:
    如果 umask得奇数位,用 666-umask 后,将 umask 的奇数位加1。
    比如 umask =303, 那么文件权限是:666-303= 363,363+101=464,即 -r–rw-r–
$ umask 303
$ touch msk_303
$ ls -l
-r--rw-r-- 1 szz szz    0 Nov 29 06:39 msk_303
  1. uid/gid
  • uid
  • uid 应用的对象是 命令,而不是文件。
  • suid 仅该指令执行过程中有效。
  • 指令经过 suid 后,任意用户在执行该指令时,都可获得该指令对应的拥有者所具有的权限。
  • 修改密码的指令权限如下,在用户位权限上有个 s,就是代表 suid
$ ls -l /usr/bin/passwd
-rwsr-xr-x 1 root root 59640 Mar 22  2019 /usr/bin/passwd
  • 注意:用户权限前三位上的x位上如果有s就表示 suid,当x位置上没有x时, suid 就是 S
    现在有如下目录结构:
Permission/
└── test
  • 权限:
drwxrwxr-x 2 root root   4096 Nov 29 19:06 Permission
-rw-r--r-- 1 root root    0   Nov 29 19:06 test
  • 普通用户 sz想要删除文件 test 权限不够。
$ rm test
rm: remove write-protected regular empty file 'test'? Y
rm: cannot remove 'test': Permission denied
  • 经过给指令 rm 设置uid之后,即设置命令rm具有所属的用户权限。比如:
$ which rm
/bin/rm
$ ls -l /bin/rm
-rw-r-xr-x 1 root root 63704 Jan 18  2018 /bin/rm
$ sudo chmod u+s `which rm`
$ ls -l /bin/rm
-rwsr-xr-x 1 root root 63704 Jan 18  2018 /bin/rm
$ rm test  # 删除成功
  • 上面都设置 uid 功能就是使得 rm 命令具有其所属的 root 具有的权限。
    注意rm命令比较危险,需要将其命令改回去。
$ sudo chmod 755 /bin/rm
$ ls -l /bin/rm
-rwxr-xr-x 1 root root 63704 Jan 18  2018 /bin/rm
  • sgidsgidsuid不同地方是sgid即可以对文件也可以针对目录设置。
  • 针对文件
  • sgid 针对二进制程序有效
  • 二进制命令或者程序需要可执行权限x
  • 指令经过 sgid 后,任意用户在执行该指令时,都可获得该指令对应的所属组具有的权限。
  • 对于目录
  • 用户在此目录下创建的文件和目录,都有和此目录相同的用户组。
  • suid/sgid的数字权限设置方法suid/sgid位设置也是八进制。
  • setuid 占用的是八进制:4000
  • setgid 占用的是2000
  • 粘滞位:占用的是 1000
    在之前的chmod命令前面加上 4/2/1 即可。

相关文章
|
8月前
|
算法 安全 Linux
Linux粘滞位(Sticky Bit)与文件权限的深度解析
Linux粘滞位(Sticky Bit)与文件权限的深度解析
239 0
|
8月前
|
存储 Linux 数据安全/隐私保护
Linux文件权限及用户管理
Linux文件权限及用户管理
59 0
|
8月前
|
安全 Linux 数据安全/隐私保护
【Linux】深入理解Linux文件权限
【Linux】深入理解Linux文件权限
109 0
|
2月前
|
存储 安全 Linux
|
7月前
|
Linux
linux查看修改文件权限
linux查看修改文件权限
59 4
|
4月前
|
安全 Linux 数据安全/隐私保护
探索Linux操作系统的文件权限管理
【9月更文挑战第29天】在数字世界中,文件权限管理如同保护我们隐私的锁。本文将带你了解如何在Linux系统中设置和管理文件权限,确保你的数据安全。我们将一起学习如何通过命令行工具来控制文件访问,就像学习一门新语言一样有趣。准备好了吗?让我们一起开启这场技术之旅!
|
3月前
|
Linux
linux/mac 下查看、修改文件权限的命令
这篇文章介绍了在Linux和Mac操作系统下如何查看和修改文件及文件夹的权限。
92 0
|
5月前
|
Linux 开发工具
在Linux中,文件权限有哪些?有什么作用?
在Linux中,文件权限有哪些?有什么作用?
|
5月前
|
Linux 数据安全/隐私保护
在Linux中,什么是文件权限?什么是rwx权限模型?
在Linux中,什么是文件权限?什么是rwx权限模型?
|
8月前
|
安全 Ubuntu Shell
Linux之用户权限和文件权限详解
Linux之用户权限和文件权限详解
100 0