linux c中ACCESS函数

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_33573235/article/details/79168796


1.函数功能:

检查调用进程是否可以对指定的文件执行某种操作。

2.函数原型:

1)函数头文件

  1. #include <stdio.h>  
  2. #include <unistd.h>  
#include <stdio.h>
#include <unistd.h>

2)函数

  1. int access(const char * pathname, int mode)  
int access(const char * pathname, int mode)

3)形参

pathname:需要检测的文件路劲名

mode:需要测试的操作模式。调用open函数时,是以有效用户而不是实际用户的身份去验证的进程对要打开的文件的读写权限。但是有时候我们想知道的是实际用户而非有效用户对某一文件的权限,此时就要用到access函数。


  1. #include<unistd.h>  
  2. int access(const char* pathname, int mode);  
  3. int faccessat(int fd, const char* pathname, int mode, int flag);  

4)函数返回值说明

成功执行时,返回0。失败返回-1,errno被设为以下的某个值 
EINVAL: 模式值无效 
EACCES: 文件或路径名中包含的目录不可访问 
ELOOP : 解释路径名过程中存在太多的符号连接 
ENAMETOOLONG:路径名太长 
ENOENT:路径名中的目录不存在或是无效的符号连接 
ENOTDIR: 路径名中当作目录的组件并非目录 
EROFS: 文件系统只读 
EFAULT: 路径名指向可访问的空间外 
EIO:输入输出错误 
ENOMEM: 不能获取足够的内核内存 
ETXTBSY:对程序写入出错

5)mode说明

  1. R_OK      测试读许可权  
  2. W_OK      测试写许可权  
  3. X_OK      测试执行许可权  
  4. F_OK      测试文件是否存在  
R_OK      测试读许可权
W_OK      测试写许可权
X_OK      测试执行许可权
F_OK      测试文件是否存在

3.函数实例

  1. #include <stdio.h>  
  2. #include <unistd.h>  
  3.   
  4. int main(void)  
  5. {  
  6. if(access("test.txt", R_OK)==0)  printf("READ OK\n");  
  7.  if(access("test.txt", W_OK)==0)  printf("WRITE OK\n");  
  8.  if(access("test.txt", X_OK)==0)  printf("EXEC OK\n");  
  9.  if(access("test.txt", F_OK)==0)   printf("File exist\n"); 



#include<unistd.h>
int access(const char* pathname, int mode);
int faccessat(int fd, const char* pathname, int mode, int flag);
先说简单的access函数,pathname是文件的路径名+文件名,指定要测试的文件;mode则指明测试哪种权限,实际上有4种:

  • F_OK 值为0,判断文件是否存在
  • R_OK 值为4判断对文件是否有读权限
  • W_OK 值为2判断对文件是否有写权限
  • X_OK 值为1判断对文件是否有读写权限
对于后三种情况,可以用“或”的方法将多种情况合在一起测试,比如R_OK | W_OK就代表测试进程对文件的读写权限.

对于faccessat函数,其用fd来指定目录,mode的含义不变,而flag可以指定是判断有效用户的权限还是实际用户的权限。

如果flag的值是AF_EACCESS(值为0x200)的话,判断的是有效用户的权限;

如果flag的值是0的话,则跟access一样,判断的是实际用户的权限。

当判断有权限时,返回0,否则返回-1.

举例如下:

展开阅读全文

没有更多推荐了,返回首页