3.2.5.文件权限管理2

文章介绍了Linux系统中关于文件权限管理的相关函数和命令,包括access用于检查文件权限,chmod用于修改文件权限,chown用于改变文件所有者,以及umask用于设置文件创建时的默认权限。示例代码展示了如何使用这些功能进行实际操作。
摘要由CSDN通过智能技术生成

3.2.5.文件权限管理2
3.2.5.1、access函数检查权限设置
(1)文本权限管控其实蛮复杂,一般很难很容易的确定对一个文件是否具有某种权限

设计优秀的软件应该是:在操作某个文件之前先判断当前是否有权限做这个操作,如果有再做,如果没有则提供错误信息给用户。


(2)access函数可以测试得到当前执行程序的  <那个用户>  在当前那个环境下对目标文件是否具有某种操作权限。

实例

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


#define NAME  "3.txt"

int main(void)
{
	int ret = -1;
	/*    F_OK          */
	ret = access(NAME, F_OK);
	if(ret < 0)
	{
		printf("文件不存在 \n");
		return -1;
	}
	else
	{
		printf("F_OK 文件存在!\n");
	}
	
		/*    R_OK          */
	ret = access(NAME, R_OK);
	if(ret < 0)
	{
		printf("文件不可读\n");
	}
	else
	{
		printf("R_OK 可读!\n");
	}
	
	
		/*    W_OK          */
	ret = access(NAME, W_OK);
	if(ret < 0)
	{
		printf("文件不可写 \n");
	}
	else
	{
		printf("W_OK 可写!\n");
	}
	
		/*    X_OK          */
	ret = access(NAME, X_OK);
	if(ret < 0)
	{
		printf("文件不可执行 \n");
	}
	else
	{
		printf("X_OK 可执行!\n");
	}
	
	
	return 0;
}

 运行结果:

 

chmod a-x 3.txt 
 

3.2.5.2、chmod/fchmod与权限修改
(1) chmod是一个linux命令,用来修改文件的各种权限属性chmod命令只有root用户才有权利去执行修改。
(2)chmod命令其实内部是用linux的一个叫chmod的API实现的。

man 1 chmod  是命令

 man 2 chmod 是 函数

 

 1. 实现 chmod 命令的 代码:

#include <stdio.h>
#include <sys/stat.h>



int main(int argc, char **argv)
{
	int ret = -1; 
	
	if(argc != 2)
	{
		printf("usage: %s filename", argv[0]);
	}
	           /* 用户可读 |  用户可写 | 用户可执行                  */
	ret = chmod(argv[1], S_IRUSR |  S_IWUSR |   S_IXUSR );
	
	if(ret < 0)
	{
		perror("chmod");
		return -1;
	}
	
	
	return 0;
}


运行结果:

2.增加      |  组 可读 |  组 可写 | 组 可执行  

|  S_IRGRP  |  S_IWGRP |    S_IXGRP

#include <stdio.h>
#include <sys/stat.h>



int main(int argc, char **argv)
{
	int ret = -1; 
	
	if(argc != 2)
	{
		printf("usage: %s filename", argv[0]);
	}
	           /* 用户可读 |  用户可写 | 用户可执行     |  组 可读 |  组 可写 | 组 可执行               */
	ret = chmod(argv[1], S_IRUSR |  S_IWUSR |   S_IXUSR |  S_IRGRP  |  S_IWGRP | S_IXGRP );
	
	if(ret < 0)
	{
		perror("chmod");
		return -1;
	}
	
	
	return 0;
}

运行结果:

 3. 增加 其他用户 可读、可写、可执行

 S_IROTH   |     S_IWOTH    |     S_IXOTH 

#include <stdio.h>
#include <sys/stat.h>



int main(int argc, char **argv)
{
	int ret = -1; 
	
	if(argc != 2)
	{
		printf("usage: %s filename", argv[0]);
	}
	         /* 用户可读 |  用户可写 | 用户可执行     |  组 可读 |  组 可写 | 组 可执行  | 其他用户 可读 |  其他用户 可写 | 其他用户 可执行                      */
	ret = chmod(argv[1], S_IRUSR |  S_IWUSR |   S_IXUSR |  S_IRGRP  |  S_IWGRP | S_IXGRP  |  S_IROTH |  S_IWOTH  |   S_IXOTH );
	
	if(ret < 0)
	{
		perror("chmod");
		return -1;
	}
	
	
	return 0;
}

运行结果:

 chmod 命令:

     chmod 命令在 可以执行   属主 目录下的1.txt文件!!!

 现在 我切换到 aston 目录:

 如果我 root 用户 呢???

 3.2.5.3、chown/fchown/lchown与属主修改
 

(1)linux中有个  chown命令来修改文件属主 

(2)chown命令是用chown API实现的

 chown root 1.txt : 一个用来修改  用户
 chgrp  root 1.txt  : 一个用来修改 组
 

 fchown: 修改文件

lchown  : 符号链接

3.2.5.4、umask与文件权限掩码
(1) 文件掩码是linux系统中维护的一个全局设置,umask的作用是用来设定我们系统中新创建的文件的默认权限的
(2)umask命令就是用umask API实现的

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大漠飞鹰6666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值