初识linux chmod时我就产生一个有趣疑问:既然chmod可以改变权限, 那即使某用户原来没有某文件的权限, 也可以自己添加权限啊!不是有chmod么?
事实并非如此。 要明白:为了用chmod改变一个文件的权限, 进程的用户ID比如等于文件所有者的ID(当然, root用户肯定可以改), 也就是说, taoge创建的文件, 文件就属于taoge所有, meinv是不能用chmod来改变文件权限的。
下面, 我们来看看:
[taoge@localhost learn_c]$ umask
0002
[taoge@localhost learn_c]$ touch a.txt
[taoge@localhost learn_c]$ ls -l
total 0
-rw-rw-r-- 1 taoge taoge 0 May 5 08:10 a.txt
[taoge@localhost learn_c]$ chmod 777 a.txt
[taoge@localhost learn_c]$ su meinv
Password:
[meinv@localhost learn_c]$ chmod 666 a.txt
chmod: changing permissions of `a.txt': Operation not permitted
[meinv@localhost learn_c]$
0002
[taoge@localhost learn_c]$ touch a.txt
[taoge@localhost learn_c]$ ls -l
total 0
-rw-rw-r-- 1 taoge taoge 0 May 5 08:10 a.txt
[taoge@localhost learn_c]$ chmod 777 a.txt
[taoge@localhost learn_c]$ su meinv
Password:
[meinv@localhost learn_c]$ chmod 666 a.txt
chmod: changing permissions of `a.txt': Operation not permitted
[meinv@localhost learn_c]$
taoge常见的文件是taoge的, meinv怎么能动呢? 如上是chmod命令, 下面, 我们来看看chmod函数, 代码如下:
#include <stdio.h>
int main()
{
if(chmod("a.txt", 777) < 0)
{
perror("error");
return 1;
}
printf("ok\n");
return 0;
}
结果如下:
[taoge@localhost learn_c]$ umask
0002
[taoge@localhost learn_c]$ ls
test.c
[taoge@localhost learn_c]$ gcc test.c
[taoge@localhost learn_c]$ ./a.out
error: No such file or directory
[taoge@localhost learn_c]$ touch a.txt
[taoge@localhost learn_c]$ ./a.out
ok
[taoge@localhost learn_c]$ su meinv
Password:
[meinv@localhost learn_c]$ ./a.out
error: Operation not permitted
[meinv@localhost learn_c]$
0002
[taoge@localhost learn_c]$ ls
test.c
[taoge@localhost learn_c]$ gcc test.c
[taoge@localhost learn_c]$ ./a.out
error: No such file or directory
[taoge@localhost learn_c]$ touch a.txt
[taoge@localhost learn_c]$ ./a.out
ok
[taoge@localhost learn_c]$ su meinv
Password:
[meinv@localhost learn_c]$ ./a.out
error: Operation not permitted
[meinv@localhost learn_c]$
可见, 文件是taoge的, meinv确实动(用chmod)不了。
OK, 本文就先聊到这里了。