linux access函数判断文件存取权限

本文详细介绍了access函数的功能与用法,包括如何检查文件的读、写和执行权限,以及如何判断文件是否存在。此外还提供了示例代码展示如何使用access函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

access(判断是否具有存取文件的权限)
相关函数
 stat,open,chmod,chown,setuid,setgid
表头文件
 #include<unistd.h>
定义函数
 int access(const char * pathname,int mode);
函数说明
 access()会检查是否可以读/写某一已存在的文件。参数mode有几种情况组合, R_OK,W_OK,X_OK 和F_OK。R_OK,W_OK与X_OK用来检查文件是否具有读取、写入和执行的权限。F_OK则是用来判断该文件是否存在。由于access()只作权限的核查,并不理会文件形态或文件内容,因此,如果一目录表示为“可写入”,表示可以在该目录中建立新文件等操作,而非意味此目录可以被当做文件处理。例如,你会发现DOS的文件都具有“可执行”权限,但用execve()执行时则会失败。
返回值
 若所有欲查核的权限都通过了检查则返回0值,表示成功,只要有一权限被禁止则返回-1。
错误代码
 EACCESS 参数pathname 所指定的文件不符合所要求测试的权限。
EROFS 欲测试写入权限的文件存在于只读文件系统内。
EFAULT 参数pathname指针超出可存取内存空间。
EINVAL 参数mode 不正确。
ENAMETOOLONG 参数pathname太长。
ENOTDIR 参数pathname为一目录。
ENOMEM 核心内存不足
ELOOP 参数pathname有过多符号连接问题。
EIO I/O 存取错误。
附加说明
 使用access()作用户认证方面的判断要特别小心,例如在access()后再做open()的空文件可能会造成系统安全上的问题。
范例
 /* 判断是否允许读取/etc/passwd */
#include<unistd.h>
int main()
{
if (access(“/etc/passwd”,R_OK) = =0)
printf(“/etc/passwd can be read/n”);
}
执行
 /etc/passwd can be read
文章出处:飞诺网(
www.firnow.com):http://dev.firnow.com/course/3_program/vc/vc_js/20090327/163611.html

Linux实验三中,你需要使用C语言结合标准库中的`stat`、`access`和`chmod`等函数来完成对文件的分析和权限更改。以下是一个简单的示例程序: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/stat.h> #include <fcntl.h> // 判断文件类型 enumFileType { FILE_TYPE_UNKNOWN, FILE_TYPE_REGULAR, FILE_TYPE_DIR, FILE_TYPE_SYMLINK, }; enumFileType getFileType(const char* filename) { struct stat stbuf; int ret = stat(filename, &stbuf); if (ret != 0) { perror("Stat failed"); return FILE_TYPE_UNKNOWN; } switch (stbuf.st_mode & S_IFMT) { case S_IFREG: return FILE_TYPE_REGULAR; case S_IFDIR: return FILE_TYPE_DIR; case S_IFLNK: return FILE_TYPE_SYMLINK; default: return FILE_TYPE_UNKNOWN; } } // 获取文件权限信息 void printPermissions(const char* filename) { struct stat stbuf; int ret = stat(filename, &stbuf); if (ret != 0) { perror("Stat failed"); return; } printf("File Type: %s\n", getFileType(filename) == FILE_TYPE_REGULAR ? "Regular File" : getFileType(filename) == FILE_TYPE_DIR ? "Directory" : "Symbolic Link"); printf("Inode Node ID: %ld\n", stbuf.st_ino); printf("Links: %lu\n", stbuf.st_nlink); printf("User ID: %d\n", stbuf.st_uid); printf("Group ID: %d\n", stbuf.st_gid); printf("Size: %lld bytes\n", stbuf.st_size); } // 修改文件权限 void changePermissions(const char* filename) { mode_t new_mask = S_IRUSR | S_IWUSR | S_IXUSR | S_IRGRP | S_IWGRP | S_IXGRP; // 允许当前用户和组内的用户读写 if (chmod(filename, new_mask) != 0) { perror("Failed to change permissions"); } else { printf("Permissions changed successfully.\n"); } } int main() { char filename[100]; printf("Enter file name: "); fgets(filename, sizeof(filename), stdin); filename[strcspn(filename, "\n")] = '\0'; printPermissions(filename); changePermissions(filename); return 0; } ``` 这个程序会提示用户输入文件名,然后获取并打印文件类型、inode信息、链接数、用户ID、组ID和文件大小。接着,它会尝试将文件权限改为允许当前用户及组内的用户读写。 请注意,实际运行时可能需要处理异常情况,比如文件不存在、路径错误等。此外,对于敏感操作,如修改权限,需要谨慎处理,确保程序安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值