LinuxC獲取檔案的權限
- 1、struct stat介紹
- 2、獲取檔案權限
- 3、編譯運行
1、struct stat介紹
我們在Linux中每個檔案都對應的有相應的屬性,這些屬性都保存在一個叫struct stat的結構體中,其中的屬性如下,
內核中struct stat 結構體:
struct stat {
mode_t st_mode; //檔案對應的模式,檔案,目錄等
ino_t st_ino; //inode節點號
dev_t st_dev; //設備號碼
dev_t st_rdev; //特殊設備號碼
nlink_t st_nlink; //檔案的連接數
uid_t st_uid; //檔案所有者
gid_t st_gid; //檔案所有者對應的組
off_t st_size; //普通檔案,對應的檔案位元組數
time_t st_atime; //檔案最后被訪問的時間
time_t st_mtime; //檔案內容最后被修改的時間
time_t st_ctime; //檔案狀態改變時間
blksize_t st_blksize; //檔案內容對應的塊大小
blkcnt_t st_blocks; //偉建內容對應的塊數量
};
stat結構體中的st_mode 則定義了下列數種情況:
S_IFMT 0170000 檔案型別的位遮罩
S_IFSOCK 0140000 scoket
S_IFLNK 0120000 符號連接
S_IFREG 0100000 一般檔案
S_IFBLK 0060000 區塊裝置
S_IFDIR 0040000 目錄
S_IFCHR 0020000 字符裝置
S_IFIFO 0010000 先進先出
S_ISUID 04000 檔案的(set user-id on execution)位
S_ISGID 02000 檔案的(set group-id on execution)位
S_ISVTX 01000 檔案的sticky位
S_IRUSR(S_IREAD) 00400 檔案所有者具可讀取權限
S_IWUSR(S_IWRITE)00200 檔案所有者具可寫入權限
S_IXUSR(S_IEXEC) 00100 檔案所有者具可執行權限
S_IRGRP 00040 用戶組具可讀取權限
S_IWGRP 00020 用戶組具可寫入權限
S_IXGRP 00010 用戶組具可執行權限
S_IROTH 00004 其他用戶具可讀取權限
S_IWOTH 00002 其他用戶具可寫入權限
S_IXOTH 00001 其他用戶具可執行權限
2、獲取檔案權限
#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>
#define N_BITS 3
int main(int argc,char *argv[])
{
unsigned int i,mask=0700;
struct stat buff;
static char *perm[]={"---","--x","-w-","-wx","r--","r-x","rw-","rwx"};
if(argc>1)
{
if((stat(argv[1],&buff)!=-1))
{
printf("permissions for %s\t",argv[1]);
for(i=3;i;--i)
{
printf("%3s",perm[(buff.st_mode&mask)>>(i-1)*N_BITS]);
mask>>=N_BITS;
}
putchar('\n');
}
else
{
perror(argv[1]);
exit(1);
}
}
else
{
fprintf(stderr,"Usage:%s file_name\n",argv[0]);
}
return 0;
}
3、編譯運行

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/278535.html
標籤:其他
下一篇:如何用單片機去寫一個呼吸燈
