linux权限suid

1.创建文件1.txt,属于root用户,root组,权限为700
2.创建程序文件
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>

#define BUFFSIZE 10

int main()
{
int fd;
char buf[BUFFSIZE];
fd = open("1.txt", O_RDWR);
if(fd < 0)
{
perror("1.txt");
return 1;
}
if(read(fd, buf, 10) < 0)
{
perror("1.txt");
return 1;
}
//打印进程uid,有效uid
printf("%d %d %s\n", getuid(), geteuid(), buf);
exit(1);
}
编译成a.out二进制文件
3.二进制文件a.out权限修改为4770,用户属于root,组为当前用户所在组,执行./a.out可以执行成功,因为进程有效用户已经为root

猜你喜欢

转载自blog.51cto.com/hjun169/2299403