更深入地了解 Linux 权限 | Linux 中国
2019-06-07 17:03
555 查看
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/F8qG7f9YD02Pe/article/details/91349637
在 Linux 上查看文件权限时,有时你会看到的不仅仅是普通的 r、w、x 和 -。如何更清晰地了解这些字符试图告诉你什么以及这些权限如何工作?-- Sandra Henry-stocker
在 Linux 上查看文件权限时,有时你会看到的不仅仅是普通的
r、
w、
x和
-。除了在所有者、组和其他中看到
rwx之外,你可能会看到
s或者
t,如下例所示:
drwxrwsrwt
stat命令查看权限。
stat的第四行输出以八进制和字符串格式显示文件权限:
$ stat /var/mail
File: /var/mail
Size: 4096 Blocks: 8 IO Block: 4096 directory
Device: 801h/2049d Inode: 1048833 Links: 2
Access: (3777/drwxrwsrwt) Uid: ( 0/ root) Gid: ( 8/ mail)
Access: 2019-05-21 19:23:15.769746004 -0400
Modify: 2019-05-21 19:03:48.226656344 -0400
Change: 2019-05-21 19:03:48.226656344 -0400
Birth: -
3777(二进制
011111111111)表示使用了两个额外的设置。该值的第一个
1(第二位)表示 SGID(设置 GID),为运行文件而赋予临时权限,或以该关联组的权限来使用目录。
011111111111
^
1(第三位)是“粘连”位。它确保只有文件的所有者能够删除或重命名该文件或目录。
011111111111
^
7777而不是
3777,我们知道 SUID(设置 UID)字段也已设置。
111111111111
^
/var/mail目录,所有用户都需要访问,因此需要一些特殊值来提供它。但现在让我们更进一步。特殊权限位的一个常见用法是使用
passwd之类的命令。如果查看
/usr/bin/passwd文件,你会注意到 SUID 位已设置,它允许你更改密码(以及
/etc/shadow文件的内容),即使你是以普通(非特权)用户身份运行,并且对此文件没有读取或写入权限。当然,
passwd命令很聪明,不允许你更改其他人的密码,除非你是以 root 身份运行或使用
sudo。
$ ls -l /usr/bin/passwd
-rwsr-xr-x 1 root root 63736 Mar 22 14:32 /usr/bin/passwd
$ ls -l /etc/shadow
-rw-r----- 1 root shadow 2195 Apr 22 10:46 /etc/shadow
chmod命令允许你以数字方式或使用字符表达式更改权限。要以数字方式更改文件权限,你可以使用这样的命令来设置 SUID 和 SGID 位:
$ chmod 6775 tryme
$ chmod ug+s tryme <== 用于 SUID 和 SGID 权限
$ cat tryme
#!/bin/bash
echo I am $USER
$ ls -l tryme
-rwsrwsrwt 1 root root 29 May 26 12:22 tryme
$ ./tryme
I am jdoe
#include <stdlib.h>
int main()
{
FILE *fp; /* file pointer*/
char fName[20];
printf("Enter the name of file to be created: ");
scanf("%s",fName);
/* create the file with write permission */
fp=fopen(fName,"w");
/* check if file was created */
if(fp==NULL)
{
printf("File not created");
exit(0);
}
printf("File created successfully\n");
return 0;
}
sudo权限才能运行一些需要的命令。
$ cc -o mkfile mkfile.c <== 编译程序
$ sudo chown root:root mkfile <== 更改所有者和组为 “root”
$ sudo chmod ug+s mkfile <== 添加 SUID and SGID 权限
$ ./mkfile <== 运行程序
Enter name of file to be create: empty
File created successfully
$ ls -l empty
-rw-rw-r-- 1 root root 0 May 26 13:15 empty
via: https://www.networkworld.com/article/3397790/a-deeper-dive-into-linux-permissions.html作者:Sandra Henry-Stocker 选题:lujun9972 译者:geekpi 校对:wxy本文由 LCTT 原创编译,Linux中国 荣誉推出
相关文章推荐
- 更深入地了解 Linux 权限 | Linux 中国
- 深入了解Linux远程桌面
- 深入理解Linux权限
- Linux文件权限隐藏的细节深入分析
- 有所为,有所不为:在 Linux 中使用超级用户权限 | Linux 中国
- linux lvm深入了解
- 关于linux load average的深入了解
- Linux怎么更改文件的权限,更改权限有哪几种方式以及权限更入了解
- Linux Bash Shell高级重定向操作--深入了解标准错误输出和标准输出
- 一张图带你深入了解Linux
- Linux 深入理解进程权限
- 深入理解linux的权限设置和SUID,SGID
- 深入了解 Linux下安装DNS+Sendmail服务
- 深入了解linux下iptables
- 深入了解Linux I/O重定向
- 带您深入了解oracle权限管理
- 如何深入了解Linux
- 深入了解Linux的守护进程(daemons)
- 深入理解Linux中的文件权限
- 深入理解linux的权限设置和SUID,SGID以及粘滞位