基于linux下的高并发服务器开发(第一章)- 模拟实现 ls-l 命令

这一小节会用到上面两张图的红色框里面的变量

任务:

模拟实现 ls -l 指令

-rw-rw-r-- 1 nowcoder nowcoder 12 12月 3 15:48 a.txt

cpp 复制代码
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <pwd.h>
#include <grp.h>
#include <time.h>
#include <string.h>

// 模拟实现 ls -l 指令
// -rw-rw-r-- 1 nowcoder nowcoder 12 12月  3 15:48 a.txt
int main(int argc, char * argv[]) {

    // 判断输入的参数是否正确
    if(argc < 2) {
        printf("%s filename\n", argv[0]);
        return -1;
    }

    // 通过stat函数获取用户传入的文件的信息
    struct stat st;
    int ret = stat(argv[1], &st);
    if(ret == -1) {
        perror("stat");
        return -1;
    }

    // 获取文件类型和文件权限
    char perms[11] = {0};   // 用于保存文件类型和文件权限的字符串
    
    //(st_mode & S_IFMT) == S_IFREG
    switch(st.st_mode & S_IFMT) { //S_IFMT:掩码 
        case S_IFLNK:         // S_IFLNK:符号链接(软链接)
            perms[0] = 'l';
            break;
        case S_IFDIR:         // S_IFDIR:目录
            perms[0] = 'd';
            break;
        case S_IFREG:         // S_IFREG:符号链接
            perms[0] = '-';
            break; 
        case S_IFBLK:         // S_IFBLK:块设备
            perms[0] = 'b';
            break; 
        case S_IFCHR:         // S_IFCHR:字符设备
            perms[0] = 'c';
            break; 
        case S_IFSOCK:         // S_IFSOCK:套接字
            perms[0] = 's';
            break;
        case S_IFIFO:         // S_IFIFO:管道
            perms[0] = 'p';
            break;
        default:
            perms[0] = '?';
            break;
    }

    // 判断文件的访问权限

    // 文件所有者 User
    perms[1] = (st.st_mode & S_IRUSR) ? 'r' : '-';//st.st_mode文件的类型和存取的权限
    perms[2] = (st.st_mode & S_IWUSR) ? 'w' : '-';
    perms[3] = (st.st_mode & S_IXUSR) ? 'x' : '-';

    // 文件所在组 Group
    perms[4] = (st.st_mode & S_IRGRP) ? 'r' : '-';
    perms[5] = (st.st_mode & S_IWGRP) ? 'w' : '-';
    perms[6] = (st.st_mode & S_IXGRP) ? 'x' : '-';

    // 其他人 Others
    perms[7] = (st.st_mode & S_IROTH) ? 'r' : '-';
    perms[8] = (st.st_mode & S_IWOTH) ? 'w' : '-';
    perms[9] = (st.st_mode & S_IXOTH) ? 'x' : '-';

    // 硬连接数
    int linkNum = st.st_nlink;//st_nlink 连到该文件的硬连接数目

    // 文件所有者
    char * fileUser = getpwuid(st.st_uid)->pw_name;//st_uid 用户ID

    // 文件所在组
    char * fileGrp = getgrgid(st.st_gid)->gr_name;//st_gid 组ID

    // 文件大小
    long int fileSize = st.st_size;//st.st_size 文件字节数(文件大小)

    // 获取修改的时间
    char * time = ctime(&st.st_mtime);//st.st_mtime最后一次修改事件

    //去除换行符
    char mtime[512] = {0};
    strncpy(mtime, time, strlen(time) - 1);

    char buf[1024];
    sprintf(buf, "%s %d %s %s %ld %s %s", perms, linkNum, fileUser, fileGrp, fileSize, mtime, argv[1]);

    printf("%s\n", buf);

    return 0;
}
相关推荐
橘子真甜~3 分钟前
C/C++ Linux网络编程15 - 网络层IP协议
linux·网络·c++·网络协议·tcp/ip·计算机网络·网络层
拾贰_C1 小时前
【Linux | Windows | Terminal Command】 Linux---grep | Windows--- findstr
linux·运维·服务器
阿华hhh2 小时前
Linux系统编程(标准io)
linux·开发语言·c++
虹科网络安全2 小时前
艾体宝洞察 | 利用“隐形字符”的钓鱼邮件:传统防御为何失效,AI安全意识培训如何补上最后一道防线
运维·网络·安全
石像鬼₧魂石2 小时前
Kali Linux 网络端口深度扫描
linux·运维·网络
alengan2 小时前
linux上面写python3日志服务器
linux·运维·服务器
yBmZlQzJ3 小时前
免费内网穿透-端口转发配置介绍
运维·经验分享·docker·容器·1024程序员节
JH30733 小时前
docker 新手入门:10分钟搞定基础使用
运维·docker·容器
Rose sait3 小时前
【环境配置】Linux配置虚拟环境pytorch
linux·人工智能·python
小卒过河01044 小时前
使用apache nifi 从数据库文件表路径拉取远程文件至远程服务器目的地址
运维·服务器·数据库