如何读取Linux的文件在C / C编程++权限 [英] How to read linux file permission programmatically in C/C++
本文介绍了如何读取Linux的文件在C / C编程++权限的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我怎么可以阅读编程,而不是使用LSLinux的文件权限,然后解析结果。
How can I read linux file permission programmatically instead using "ls" then parse the result.
推荐答案
的 STAT(2)
系统调用返回 struct stat中
包含 ST_MODE
成员。这是模式比特的ls -l </ code>显示。
The stat(2)
system call returns a struct stat
that contains a st_mode
member. This is the mode bits that ls -l
displays.
在我的系统中, 2人统计
页说:
The following flags are defined for the st_mode field:
S_IFMT 0170000 bitmask for the file type bitfields
S_IFSOCK 0140000 socket
S_IFLNK 0120000 symbolic link
S_IFREG 0100000 regular file
S_IFBLK 0060000 block device
S_IFDIR 0040000 directory
S_IFCHR 0020000 character device
S_IFIFO 0010000 FIFO
S_ISUID 0004000 set UID bit
S_ISGID 0002000 set-group-ID bit (see below)
S_ISVTX 0001000 sticky bit (see below)
S_IRWXU 00700 mask for file owner permissions
S_IRUSR 00400 owner has read permission
S_IWUSR 00200 owner has write permission
S_IXUSR 00100 owner has execute permission
S_IRWXG 00070 mask for group permissions
S_IRGRP 00040 group has read permission
S_IWGRP 00020 group has write permission
S_IXGRP 00010 group has execute permission
S_IRWXO 00007 mask for permissions for others (not in group)
S_IROTH 00004 others have read permission
S_IWOTH 00002 others have write permission
S_IXOTH 00001 others have execute permission
这篇关于如何读取Linux的文件在C / C编程++权限的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文