#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <string.h> #define ERR_EXIT( m ) \
do\
{ \
perror( m ); \
exit( EXIT_FAILURE ); \
}while( 0 ) #define MAJOR( a ) (int)((unsigned short)a >> 8 ) //获取高8位
#define MINOR( a ) (int)((unsigned short)a & 0xFF ) //获取低8位 //检测文件类型
int filetype( struct stat* st, char* filetype ); //检测文件权限
void fileperm( struct stat* st, char* perm ); int main( int argc, char* argv[] ) { int ret;
if( argc != 2 ) {
fprintf( stderr, "usage:%s filename\n", argv[0] );
exit( EXIT_FAILURE );
} struct stat st; ret = stat( argv[1], &st );
if( -1 == ret ) {
ERR_EXIT( "stat file error" );
} printf( "文件大小:st_size=%d\n", st.st_size );
printf( "用户id:uid=%d\n", st.st_uid );
printf( "组id:gid=%d\n", st.st_gid );
//printf( "主设备号:major_dev=%d\n", MAJOR( st.st_dev ) );
//printf( "次设备号:minor_dev=%d\n", MINOR( st.st_dev ) );
printf( "i节点:st_ino=%d\n", st.st_ino ); char filetypestr[64] = { 0 };
int ftype = filetype( &st, filetypestr );
if( ftype == 3 || ftype == 5 ) {
printf( "文件类型:%s\n", filetypestr );
printf( "主设备号:%d, 次设备号:%d\n", MAJOR( st.st_dev ), MINOR( st.st_dev ) );
}else {
printf( "文件类型:%s\n", filetypestr );
} char perm[11];
fileperm( &st, perm );
printf( "文件权限:%o, %s\n", st.st_mode & 07777, perm ); return 0;
} //检测文件类型,设置文件返回1 其他文件返回0
/*
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
*/
int filetype( struct stat* st, char* filetype ) { mode_t mode = st->st_mode;
int flag = 0; char* filetypes[] = {
"socket",
"symbolic link",
"regular file",
"block device",
"directory",
"character device",
"fifo"
}; switch( mode & S_IFMT ){
case S_IFSOCK:
strncpy( filetype, filetypes[0], strlen( filetypes[0] ) );
flag = 0;
break;
case S_IFLNK:
strncpy( filetype, filetypes[1], strlen( filetypes[1] ) );
flag = 1;
break;
case S_IFREG:
strncpy( filetype, filetypes[2], strlen( filetypes[2] ) );
flag = 2;
break;
case S_IFBLK:
strncpy( filetype, filetypes[3], strlen( filetypes[3] ) );
flag = 3;
break;
case S_IFDIR:
strncpy( filetype, filetypes[4], strlen( filetypes[4] ) );
flag = 4;
break;
case S_IFCHR:
strncpy( filetype, filetypes[5], strlen( filetypes[5] ) );
flag = 5;
break;
case S_IFIFO:
strncpy( filetype, filetypes[6], strlen( filetypes[6] ) );
flag = 6;
break;
} return flag;
} //检测文件权限
/*
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
*/
void fileperm( struct stat* st, char* perm ) { strncpy( perm, "----------", 10 );
perm[0] = '?';
mode_t mode = st->st_mode; char typestr[64] = { 0 };
char* abbreviation[] = {
"s", //socket
"l", //symbolic link
"-", //regular file
"b", //block file
"d", //directory
"c", //charactor device
"p" //fifo
}; int ret = filetype( st, typestr );
strncpy( perm, abbreviation[ret], 1 ); //检测文件所属的用户权限
if( mode & S_IRUSR ){
perm[1] = 'r';
}
if( mode & S_IWUSR ){
perm[2] = 'w';
}
if( mode & S_IXUSR ){
perm[3] = 'x';
} //检测用户组权限
if( mode & S_IRGRP ){
perm[4] = 'r';
}
if( mode & S_IWGRP ){
perm[5] = 'w';
}
if( mode & S_IXGRP ){
perm[6] = 'x';
} //检测其他组权限
if( mode & S_IROTH ){
perm[7] = 'r';
}
if( mode & S_IWOTH ){
perm[8] = 'w';
}
if( mode & S_IXOTH ){
perm[9] = 'x';
}
perm[10] = '\0';
}

  

linux编程stat检测文件元数据信息的更多相关文章

  1. Linux编程 4 (创建文件touch,复制文件cp,tab补全,链接文件ln)

    一.创建文件 使用touch 可以创建空文件,例如opt目录下创建test2.txt文件.这种一般是有些程序必须要先创建文件,才能使用. 二. 复制文件 2.1 使用cp命令来复制文件,需要两个参数- ...

  2. 【HDFS API编程】查看文件块信息

    现在我们把文件都存在HDFS文件系统之上,现在有一个jdk.zip文件存储在上面,我们想知道这个文件在哪些节点之上?切成了几个块?每个块的大小是怎么样?先上测试类代码: /** * 查看文件块信息 * ...

  3. Linux C语言 检测文件是否存在

    头文件 unistd.h ) { // file exists } else { // file doesn't exist } You can also use R_OK, W_OK, and X_ ...

  4. 【目录】linux 编程

    随笔分类 - linux 编程 Linux编程 24 shell编程(结构化 if [ condition ] 数值比较,字符串比较) 摘要: 一.概述 接着上篇讲的结构化命令,最后讲到了test命令 ...

  5. linux c编程:系统数据文件和信息

    linux系统相关的文件信息包含在/etc/passwd文件和/etc/group中.每次登录linux系统以及每次执行ls -l命令时都要使用口令文件.这些字段都包含在<pwd.h>中定 ...

  6. Linux/UNIX编程如何保证文件落盘

    本文转载自Linux/UNIX编程如何保证文件落盘 导语 我们编写程序write数据到文件中时,其实数据不会立马写入磁盘,而是会经过层层缓存.每层缓存都有自己的刷新时机,每层缓存都刷新后才会写入磁盘. ...

  7. (四) 一起学 Unix 环境高级编程(APUE) 之 系统数据文件和信息

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

  8. Python编程笔记(第三篇)【补充】三元运算、文件处理、检测文件编码、递归、斐波那契数列、名称空间、作用域、生成器

    一.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件处理: if 条件成立: val = 1 else: val = 2 改成三元运算 val = 1 if 条件成立 else ...

  9. Linux下音频编程-输出音频文件

    程序实现了在Linux下播放Ok.wav的功能.程序首先调用fstat函数获得文件相关信息(主要是文件大小信息).通过malloc函数分配指定的内存空间,并将online.wav读入内存:然后,打开声 ...

随机推荐

  1. Kingfisher

    Kingfisher ima1.kf.setImage(with: url) 为了兼容macOS, IOS 通过协议定义了kf,实际上就是本身 KingfisherOptionsInfo 可以配置一些 ...

  2. SQL Server之替换文本内容中的回车符和换行符

    UPDATE 表 SET 栏位A = REPLACE(栏位A, CHAR(10), '') UPDATE表 SET 栏位A = REPLACE(栏位A, CHAR(13), '')

  3. OAuthon2.0机制详解

    最近在忙企业微信和钉钉的第三方应用开发,需要获取一些信息,第一个就是这个OAuthon2.0,先详细了解下概念和流程 一.应用场景 我们要想用第三方播放器播放你的云盘账号里面的一些秘密视频资源,为了要 ...

  4. steamdb cookie

    steamdb cookie import requests, re, os, pymysql, time from lxml import etree from steamdb.YDM import ...

  5. Unable to open debugger port: java.net.SocketException

    网上都说是tomcat端口被占用,其实不是,这是因为文件权限不够,脚本不能执行,debug当然不能接受网络连接的数据 可以在Event Log里看到 所以只需要更改文件的级别就可以了(可读可写可执行) ...

  6. react后台项目开发(一)

    1. 项目开发准备 描述项目 技术选型 api 接口(4部分:3请求{url,请求方式,请求参数格式}, 1响应数据格式)/ 接口文档/ 测试接口 2. 启动项目开发 使用react脚手架创建项目 开 ...

  7. Unity ugui屏幕适配与世界坐标到ugui屏幕坐标的转换

    我们知道,如今的移动端设备分辨率五花八门,而开发过程中往往只取一种分辨率作为设计参考,例如采用1920*1080分辨率作为参考分辨率. 选定了一种参考分辨率后,美术设计人员就会固定以这样的分辨率来设计 ...

  8. [算法]PriorityQueue的应用

    1. 数据流中的第K大元素 题目 设计一个找到数据流中第K大元素的类(class).注意是排序后的第K大元素,不是第K个不同的元素. 你的 KthLargest 类需要一个同时接收整数 k 和整数数组 ...

  9. Git - Git分支管理策略

    前言 通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息. 如果要强制禁用Fast forward模式,Git就会在merge时生成一个新的c ...

  10. 理解并运用TP5.1-Facade

    1.内容介绍 深入解析tp5.1与laravel 中Facade底层原理实现 1. 什么是Facade 2. 为什么需要有什么好处 3.  Facade实现原理 4. 功能实现. 5. 容器注入 2. ...