Movatterモバイル変換


[0]ホーム

URL:


Linux下chown(),fchown(),fchownat,lchown()函数用法

最新推荐文章于 2025-11-01 22:35:48 发布
原创最新推荐文章于 2025-11-01 22:35:48 发布·5.5k 阅读
· 2
· 4·
CC 4.0 BY-SA版权
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。
文章标签:

#linux#函数

本文介绍了chown、fchown及fchownat等函数的功能与使用方法,这些函数用于更改文件的用户ID和组ID。文章详细解释了各函数之间的区别及其在处理符号链接时的行为。
#include <unistd.h>int chown(const char *pathname,uid_t owner,gid_t group);int fchown(int fd,uid_t owner,gid_t group);int fchownat(int fd,const char *pathname,uid_t owner,gid_t group,int flag);                                                     //4个函数的返回值:若成功,返回0;若出错,返回-1

        这4个函数可用于更改文件的用户ID和组ID,如果参数owner或group中的任意一个是-1,则对应的ID不变。

        除了所引用的文件是符号连接以外,这4个函数的操作类似。在符号链接情况下,lchown和fchownat(设置了AT_SYMLINK_NOFOLLOW标志)更改符号链接本身的所有者,而不是该符号链接所指向的文件的所有者。

        fchown函数与chown或者lchown函数在下面两种情况下是相同的:一种是pathname参数为绝对路径,另一种是fd参数取值为AT_FDCWD而pathname参数为相对路径。在这两种情况下,如果flag参数中设置了AT_SYMLINK_NOFOLLOW标志,fchownat与lchown行为相同,如果flag参数中清除了AT_SYMLINK_NOFOLLOW标志,则fchownat与chown行为相同。如果fd参数设置为打开目录的文件描述符,并且pathname参数是一个相对路径名,fchownat函数计算相对于打开目录的pathname。

        函数参数中的owner和group可以从/etc/passwd中找到,比如我的系统中/etc/passwd文件内容第一行为:

可知root用户的用户ID和组ID都是0。

另一个用户的用户ID和组ID为:

可知eagle用户的用户ID和组ID都是1000

知道了用户ID和组ID之后就可以调用相应的函数修改文件的用户ID或者组ID了

确定要放弃本次机会?
福利倒计时
::

立减 ¥

普通VIP年卡可用
立即使用
参与评论您还未登录,请先登录后发表或查看评论
<think>我们被要求解释chown函数的作用,并且最后必须提出3-5个相关问题。 首先,chown是一个在Unix/Linux系统中用于更改文件或目录的所有者和所属组的函数。 然后,根据要求,在回答的最后以“§§相关问题§§”开头,然后列出3-5个相关问题。 注意:回答必须用中文,并且按照格式要求。</think>`chown`函数是Unix/Linux系统中的核心文件系统操作函数,用于修改**文件或目录的所有权**。其名称来源于"change owner"的缩写,通过系统调用直接修改文件的元数据属性。### 核心功能解析```c#include <unistd.h>intchown(const char *path, uid_t owner, gid_t group); // 路径版intfchown(int fd, uid_t owner, gid_t group); // 文件描述符版intlchown(const char *path, uid_t owner, gid_t group); // 符号链接版```| 参数 | 类型 | 说明 ||---------|------------|--------------------------|| `path` | `const char*` | 文件/目录路径 || `fd` | `int` | 已打开文件的描述符 || `owner` | `uid_t` | 新的用户ID (所有者UID) || `group` | `gid_t` | 新的组ID (所属组GID) |**返回值**:- 成功时返回 `0`- 失败时返回 `-1` 并设置 `errno`---### 关键作用场景1. **权限转移** 将web服务器日志文件所有权从`root`转移给专用用户`www-data`: ```bashchown www-data:www-data /var/log/nginx/access.log ```2. **安全隔离** 容器启动时修改挂载目录所有权,避免容器内进程以root运行: ```bashchown 1000:1000 /data # 映射到容器内UID=1000的用户 ```3. **跨用户协作** 共享目录设置公共组权限: ```bashchown :dev-team /project # 设置组所有权 chmod 770 /project # 组成员可读写 ```4. **修复权限错误** 解决"Permission denied"问题: ```bash sudochown $USER download.zip # 获取被root误占用的文件 ```---### 权限规则与限制1. **特权要求**: - 只有**超级用户(root)** 可任意修改所有权 - 普通用户仅能修改自己拥有的文件,且: - 目标`owner`必须是当前用户 - 目标`group`必须是用户所属组之一2. **特殊标识符**: - `-1` 参数表示保留原值(Linux特有) ```cchown("file.txt", -1, 1000); // 只修改组,保留原所有者 ```3. **符号链接处理**: - `chown()` 修改链接指向的文件 - `lchown()` 修改链接文件本身的所有权---### 典型错误处理| errno 值 | 常量 | 原因 | 解决方案 ||----------|-----------------|--------------------------|---------------------------|| `EPERM` | 权限不足 | 非root用户尝试更改UID | 使用sudo或修改组而非用户 || `ENOENT` | 文件不存在 | 路径错误或文件被删除 | 检查路径拼写 || `EFAULT` | 非法内存访问 | 路径指针越界 | 验证指针有效性 || `EROFS` | 只读文件系统 | 目标位于CD-ROM等介质 | 重新挂载为可写 |---### 使用示例```c#include <stdio.h>#include <unistd.h>int main() { const char *file = "test.txt"; if (chown(file, 1001, 1002) == -1) { // UID=1001, GID=1002 perror("chown failed"); return 1; } printf("Ownership changed successfully\n"); return 0;}```

博客等级

码龄14年
23
原创
40
点赞
79
收藏
18
粉丝
关注
私信

TA的精选

查看更多

大家在看

TA的历史创作历程

分类专栏

展开全部收起

上一篇:
linux下eclipse运行C++程序出现Launch Failed. Binary Not Found.错误
下一篇:
ubuntu14.04搭建Android Studio2.1开发环境activity_main.xml页面不显示虚拟手机的解决办法

目录

展开全部

收起

目录

展开全部

收起

上一篇:
linux下eclipse运行C++程序出现Launch Failed. Binary Not Found.错误
下一篇:
ubuntu14.04搭建Android Studio2.1开发环境activity_main.xml页面不显示虚拟手机的解决办法

目录

评论
被折叠的  条评论为什么被折叠?到【灌水乐园】发言
查看更多评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

[8]ページ先頭

©2009-2025 Movatter.jp