假设系统中有一个用户组u2,其gid为502。以root身份编写并运行程序chowntest.c,创建一个f1文件(文件所有者为root,所属组为root组),将其文件所属组改为u2组。
时间: 2024-10-16 13:03:54 浏览: 20
Linux怎么给一个普通用户关机权限.pdf
在Linux系统中,你可以使用`chmod`和`chown`命令来实现这个操作。首先,假设你已经有了一个名为`chowntest.c`的源文件,并通过`gcc chowntest.c -o chowntest`编译生成了可执行文件`chowntest`。
在这个`chowntest`程序中,你需要使用`setgid()`函数来临时设置进程的gid,然后使用`open()`创建文件,并用`fchown()`函数改变文件的所有者和所属组。以下是实现该功能的一个简单的C代码示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/stat.h>
int main(int argc, char *argv[]) {
if (argc != 2) {
fprintf(stderr, "Usage: %s <filename>\n", argv[0]);
return 1;
}
char filename[] = argv[1];
gid_t old_gid = getegid(); // 获取当前进程的gid
// 设置新的gid为u2组
setgid(502); // 502是u2的gid
int fd = open(filename, O_CREAT | O_WRONLY, 0644); // 创建文件,所有者和所属组默认为当前用户和组
if (fd == -1) {
perror("Error opening file");
return 1;
}
// 改变文件所属组为u2组
if (fchown(fd, -1, 502) == -1) { // 将所属组设置为502,文件所有者保持不变(-1)
perror("Error changing group ownership");
close(fd);
return 1;
}
// 恢复进程原来的gid
setgid(old_gid);
printf("File '%s' created and changed to belong to group %d\n", filename, 502);
close(fd);
return 0;
}
```
要运行此程序,需要先切换到root权限,例如:
```sh
sudo ./chowntest f1
```
确保替换`f1`为你实际的文件名。
阅读全文