今天在ubuntu下编写一个了C程序实现如下功能:
(1)创建一个文本文件,写入“Hello World!”
(2)获取该文件的所有权限
(3)把该文件改为只读
(4)修改该文件的文件名
C语言chmod()函数:修改文件权限
函数说明:chmod()会依参数mode 权限来更改参数path 指定文件的权限。
参数 mode 有下列数种组合:
1、S_ISUID 04000 文件的 (set user-id on execution)位
2、S_ISGID 02000 文件的 (set group-id on execution)位
3、S_ISVTX 01000 文件的sticky 位
4、S_IRUSR (S_IREAD) 00400 文件所有者具可读取权限
5、S_IWUSR (S_IWRITE)00200 文件所有者具可写入权限
6、S_IXUSR (S_IEXEC) 00100 文件所有者具可执行权限
7、S_IRGRP 00040 用户组具可读取权限
8、S_IWGRP 00020 用户组具可写入权限
9、S_IXGRP 00010 用户组具可执行权限
10、S_IROTH 00004 其他用户具可读取权限
11、S_IWOTH 00002 其他用户具可写入权限
12、S_IXOTH 00001 其他用户具可执行权限
注:只有该文件的所有者或有效用户识别码为0,才可以修改该文件权限。
基于系统安全,如果欲将数据写入一执行文件,而该执行文件具有S_ISUID 或S_ISGID 权限,则这两个位会被清除。如果一目录具有S_ISUID 位权限,表示在此目录下只有该文件的所有者或root 可以删除该文件。
返回值:权限改变成功返回0, 失败返回-1, 错误原因存于errno.
错误代码:
1、EPERM 进程的有效用户识别码与欲修改权限的文件拥有者不同, 而且也不具root 权限.
2、EACCESS 参数path 所指定的文件无法存取.
3、EROFS 欲写入权限的文件存在于只读文件系统内.
4、EFAULT 参数path 指针超出可存取内存空间.
5、EINVAL 参数mode 不正确
6、ENAMETOOLONG 参数path 太长
7、ENOENT 指定的文件不存在
8、ENOTDIR 参数path 路径并非一目录
9、ENOMEM 核心内存不足
10、ELOOP 参数path 有过多符号连接问题.
11、EIO I/O 存取错误
C语言rename()函数:重命名文件或目录
【参数】oldname为旧文件名,newname为新文件名。
【返回值】修改文件名成功则返回0,否则返回-1。
重命名文件:
- 如果newname指定的文件存在,则会被删除。
- 如果newname与oldname不在一个目录下,则相当于移动文件。
重命名目录:
- 如果oldname和oldname都为目录,则重命名目录。
- 如果newname指定的目录存在且为空目录,则先将newname删除。
- 对于newname和oldname两个目录,调用进程必须有写权限。
- 重命名目录时,newname不能包含oldname作为其路径前缀。例如,不能将/usr更名为/usr/foo/testdir,因为老名字( /usr/foo)是新名字的路径前缀,因而不能将其删除。
话不多说,先上代码:
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main() {
changeFileName();
return 0;
}
int makeFile(){
FILE *fileP=NULL;
fileP=fopen("hello.txt","w");
fputs("Hello,World!\n",fileP);
fclose(fileP);
return 0;
}
int changemod()
{
chmod("hello.txt", S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IWGRP|S_IXGRP|S_IROTH|S_IWOTH|S_IXOTH);
return 0;
}
int chmodOnlyRead(){
chmod("hello.txt", S_IRUSR|S_IRGRP|S_IROTH);
return 0;
}
int changeFileName(){
rename("hello.txt","helloTest.txt");
return 0;
}
实现结果:
参考链接: