Linux系统中文件属性和权限实战操作

—–原本今天的文章是昨天晚上就要更新的,但是由于昨天晚上下班回到住的地方,发现停电了,所以就没写成。今天是在上一篇文章–linux系统中文件类型的基础上,继续进行深入的学习。好了,直接开干。

一、文件的操作权限:

1、在这之前我想还是很有必要介绍对文件的操作权限(特别是第一次接触这个的好友),主要是为了下次大家在使用命令ls -al,看不懂所查的信息。在Linux系统中,每个文件都有所属的所有者和所有组,并且规定了文件的所有者、所有组以及其他人对文件所拥有的可读(r)、可写(w)、可执行(x)等权限。对于一般文件来说,权限比较容易理解:“可读”表示能够读取文件的实际内容;“可写”表示能够编辑、新增、修改、删除文件的实际内容;“可执行”则表示能够运行一个脚本程序。但是对目录文件来说,就有点不一样了“可读”表示能够读取目录内的文件列表;“可写”表示能够在目录内新增、删除、重命名文件;而“可执行”则表示能够进入该目录(不过这里还是主要以普通文件来介绍,所以这个就不深入介绍了)。文件的读、写、执行权限可以简写为rwx,也可以可分别用数字4、2、1来表示,文件所有者,所属组及其他用户权限之间无关联,可以通过下面的表格来理解:

Linux系统中文件属性和权限实战操作

文件权限的数字法表示基于字符表示(rwx)的权限计算而来,其目的是简化权限的表示。例如,若某个文件的权限为7则代表可读、可写、可执行(4+2+1);若权限为6则代表可读、可写(4+2)。下面我以一个示例来演示:

Linux系统中文件属性和权限实战操作

二、文件属性操作:

1、在Linux系统中,每个文件中都附带了这个文件的一些属性(属性信息是存在于文件本身中的,但是它不像文件的内容一样可以被vi打开看到,属性信息只能被专用的API打开看到;常见文件属性信息查看的API有三个:stat、fstat、lstat,三个作用一样,参数不同,细节略有不同(—–fstat和stat的区别是:stat是从文件名出发得到文件属性信息结构体(命令使用时,直接就是stat FILENAME),而且这个文件时未打开的;而fstat是从一个已经打开的文件fd(文件描述符,这个我前面的文章里面有详细的介绍)出发得到一个文件的属性信息。所以用的时候如果文件没有打开(我们并不想打开文件操作而只是希望得到文件属性)那就用stat,如果文件已经被打开了然后要属性那就用fstat效率会更高(stat是从磁盘去读取文件的,而fstat是从内存读取动态文件的)———-lstat和stat/fstat的差别在于:对于符号链接文件,stat和fstat查阅的是【符号链接文件指向的那个文件的属性】,而lstat查阅的是符号链接文件本身的属性———-)。我们也可以使用命令stat来查看文件的属性的,但是实际上stat命令内部就是使用stat系统调用(也就是我们api函数stat)来实现的,查看的结果如下:

Linux系统中文件属性和权限实战操作

注:这里的最近更改(modify)指的是修改文件的内容;而最近改动(change)指的是修改文件的属性。

2、在代码实战之前,我们先来简单了解一下stat函数的使用,还是老办法,使用man 手册来查看它的用法(man 2 stat):

Linux系统中文件属性和权限实战操作
Linux系统中文件属性和权限实战操作

代码语言:javascript代码运行次数:0运行复制

struct stat {           dev_t     st_dev;         /* ID of device containing file */           ino_t     st_ino;         /* Inode number */           mode_t    st_mode;        /* File type and mode */           nlink_t   st_nlink;       /* Number of hard links */           uid_t     st_uid;         /* User ID of owner */           gid_t     st_gid;         /* Group ID of owner */           dev_t     st_rdev;        /* Device ID (if special file) */           off_t     st_size;        /* Total size, in bytes */           blksize_t st_blksize;     /* Block size for filesystem I/O */           blkcnt_t  st_blocks;      /* Number of 512B blocks allocated */           /* Since Linux 2.6, the kernel supports nanosecond              precision for the following timestamp fields.              For the details before Linux 2.6, see NOTES. */           struct timespec st_atim;  /* Time of last access */           struct timespec st_mtim;  /* Time of last modification */           struct timespec st_ctim;  /* Time of last status change */       #define st_atime st_atim.tv_sec      /* Backward compatibility */       #define st_mtime st_mtim.tv_sec       #define st_ctime st_ctim.tv_sec       };   Note: the order of fields in the stat structure varies somewhat across architectures.  In addition, the definition above does not show the padding bytes  that  may  be  present  between  some   fields on various architectures.  Consult the glibc and kernel source code if you need to know the details.Note:  for  performance and simplicity reasons, different fields in the stat structure may contain state information from different moments during the execution of the system call.  For exam‐   ple, if st_mode or st_uid is changed by another process by calling chmod(2) or chown(2), stat() might return the old st_mode together with the new st_uid, or the old st_uid together with  the   new st_mode.   The fields in the stat structure are as follows:   st_dev This field describes the device on which this file resides.  (The major(3) and minor(3) macros may be useful to decompose the device ID in this field.)   st_ino This field contains the file's inode number.   st_mode          This field contains the file type and mode.  See inode(7) for further information.   st_nlink  This field contains the number of hard links to the file.   st_uid This field contains the user ID of the owner of the file.   st_gid This field contains the ID of the group owner of the file.   st_rdev          This field describes the device that this file (inode) represents.   st_size          This field gives the size of the file (if it is a regular file or a symbolic link) in bytes.  The size of a symbolic link is the length of the pathname it contains, without a terminat‐          ing null byte.   st_blksize          This field gives the "preferred" block size for efficient filesystem I/O.   st_blocks          This field indicates the number of blocks allocated to the file, in 512-byte units.  (This may be smaller than st_size/512 when the file has holes.)   st_atime          This is the file's last access timestamp.          This is the file's last access timestamp.   st_mtime          This is the file's last modification timestamp.   st_ctime          This is the file's last status change timestamp.   For further information on the above fields, see inode(7).fstatat()   The fstatat() system call is a more general interface for accessing file information which can still provide exactly the behavior of each of stat(), lstat(), and fstat().   If the pathname given in pathname is relative, then it is interpreted relative to the directory referred to by the file descriptor dirfd (rather than relative to the current working directory   of the calling process, as is done by stat() and lstat() for a relative pathname).   If pathname is relative and dirfd is the special value AT_FDCWD, then pathname is interpreted relative to the current working directory of the calling process (like stat() and lstat()).

注:上面的英文是源解释,这里不好讲解,所以拿出来了,如果你方便的话,可以自己来查看,这样看的更舒服一点,而且顺便也可以熟悉一下这个操作,哈哈,一举两得。struct stat是内核定义的一个结构体,在中声明,所以我们可以用。这个结构体中的所有元素加起来就是我们的文件属性信息。对于int stat(const char *path, struct stat *buf)这个函数,它的作用就是让内核将我们要查找属性的文件的属性信息结构体的值放入我们传递给stat函数的buf中,当stat这个API调用从内核返回的时候buf中就被填充了文件的正确的属性信息,然后我们通过查看buf这种结构体变量的元素就可以得知这个文件的各种属性了。

3、代码实战:

a、查看文件常见属性:

代码语言:javascript代码运行次数:0运行复制

#include #include #include #include #include #include #define NAME "a.txt"int main(void){int ret = -1;struct stat buf;memset(&buf, 0, sizeof(buf));       // memset后buf中全是0ret = stat(NAME, &buf);             // stat后buf中有内容了if (ret < 0){    perror("stat");    exit(-1);}// 成功获取了stat结构体,从中可以得到各种属性信息了printf("inode = %d.n", buf.st_ino);printf("size = %d bytes.n", buf.st_size);printf("st_blksize = %d.n", buf.st_blksize);return 0;}

演示效果:

Linux系统中文件属性和权限实战操作

b、判断文件类型:

文件属性中的文件类型标志在struct stat结构体的mode_t st_mode元素中,这个元素其实是一个按位来定义的一个位标志(有点类似于ARM CPU的CPSR寄存器的模式位定义)。这个东西有很多个标志位共同构成,记录了很多信息,如果要查找文件权限功能时按位&操作就知道结果了,但是因为这些位定义不容易记住,因此linux系统给大家事先定义好了很多宏来进行相应操作,我们(只要把stat结构体中的mode_t st_mode元素作为参数传给这些宏中),根据宏的返回值就可以判断文件类型等。这个宏有以下类型:

代码语言:javascript代码运行次数:0运行复制

 S_ISREG(m)  is it a regular file?       S_ISDIR(m)  directory?       S_ISCHR(m)  character device?       S_ISBLK(m)  block device?       S_ISFIFO(m) FIFO (named pipe)?       S_ISLNK(m)  symbolic link?  (Not in POSIX.1-1996.)    //是不是一个符号链接文件       S_ISSOCK(m) socket?  (Not in POSIX.1-1996.)

譬如S_ISREG宏返回值是1表示这个文件是一个普通文件,如果文件不是普通文件则返回值是0

代码语言:javascript代码运行次数:0运行复制

#include #include #include #include #include #include #define NAME "a.txt"int main(void){   int ret = -1;    struct stat buf;    memset(&buf, 0, sizeof(buf));           // memset后buf中全是0    ret = stat(NAME, &buf);                         // stat后buf中有内容了    if (ret < 0)    {            perror("stat");            exit(-1);    }    int result = S_ISDIR(buf.st_mode);    printf("result = %dn", result);    return 0;}

演示结果:

Linux系统中文件属性和权限实战操作

代码可以在我的github上看:

https://github.com/1121518wo/linux-/tree/master

三、总结:

这里推荐一个有关Linux基础入门的知识,可以看刘遄老师的书—,这本书虽然是写运维的,但是有一些知识点,非常适合小白入门Linux的一些基本操作的————–

https://www.linuxprobe.com/chapter-02.html

以上就是Linux系统中文件属性和权限实战操作的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/24635.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月2日 07:16:22
下一篇 2025年11月2日 07:47:54

相关推荐

  • Uniapp 中如何不拉伸不裁剪地展示图片?

    灵活展示图片:如何不拉伸不裁剪 在界面设计中,常常需要以原尺寸展示用户上传的图片。本文将介绍一种在 uniapp 框架中实现该功能的简单方法。 对于不同尺寸的图片,可以采用以下处理方式: 极端宽高比:撑满屏幕宽度或高度,再等比缩放居中。非极端宽高比:居中显示,若能撑满则撑满。 然而,如果需要不拉伸不…

    2025年12月24日
    400
  • 如何让小说网站控制台显示乱码,同时网页内容正常显示?

    如何在不影响用户界面的情况下实现控制台乱码? 当在小说网站上下载小说时,大家可能会遇到一个问题:网站上的文本在网页内正常显示,但是在控制台中却是乱码。如何实现此类操作,从而在不影响用户界面(UI)的情况下保持控制台乱码呢? 答案在于使用自定义字体。网站可以通过在服务器端配置自定义字体,并通过在客户端…

    2025年12月24日
    800
  • 如何在地图上轻松创建气泡信息框?

    地图上气泡信息框的巧妙生成 地图上气泡信息框是一种常用的交互功能,它简便易用,能够为用户提供额外信息。本文将探讨如何借助地图库的功能轻松创建这一功能。 利用地图库的原生功能 大多数地图库,如高德地图,都提供了现成的信息窗体和右键菜单功能。这些功能可以通过以下途径实现: 高德地图 JS API 参考文…

    2025年12月24日
    400
  • 如何使用 scroll-behavior 属性实现元素scrollLeft变化时的平滑动画?

    如何实现元素scrollleft变化时的平滑动画效果? 在许多网页应用中,滚动容器的水平滚动条(scrollleft)需要频繁使用。为了让滚动动作更加自然,你希望给scrollleft的变化添加动画效果。 解决方案:scroll-behavior 属性 要实现scrollleft变化时的平滑动画效果…

    2025年12月24日
    000
  • 如何为滚动元素添加平滑过渡,使滚动条滑动时更自然流畅?

    给滚动元素平滑过渡 如何在滚动条属性(scrollleft)发生改变时为元素添加平滑的过渡效果? 解决方案:scroll-behavior 属性 为滚动容器设置 scroll-behavior 属性可以实现平滑滚动。 html 代码: click the button to slide right!…

    2025年12月24日
    500
  • 如何选择元素个数不固定的指定类名子元素?

    灵活选择元素个数不固定的指定类名子元素 在网页布局中,有时需要选择特定类名的子元素,但这些元素的数量并不固定。例如,下面这段 html 代码中,activebar 和 item 元素的数量均不固定: *n *n 如果需要选择第一个 item元素,可以使用 css 选择器 :nth-child()。该…

    2025年12月24日
    200
  • 使用 SVG 如何实现自定义宽度、间距和半径的虚线边框?

    使用 svg 实现自定义虚线边框 如何实现一个具有自定义宽度、间距和半径的虚线边框是一个常见的前端开发问题。传统的解决方案通常涉及使用 border-image 引入切片图片,但是这种方法存在引入外部资源、性能低下的缺点。 为了避免上述问题,可以使用 svg(可缩放矢量图形)来创建纯代码实现。一种方…

    2025年12月24日
    100
  • 如何让“元素跟随文本高度,而不是撑高父容器?

    如何让 元素跟随文本高度,而不是撑高父容器 在页面布局中,经常遇到父容器高度被子元素撑开的问题。在图例所示的案例中,父容器被较高的图片撑开,而文本的高度没有被考虑。本问答将提供纯css解决方案,让图片跟随文本高度,确保父容器的高度不会被图片影响。 解决方法 为了解决这个问题,需要将图片从文档流中脱离…

    2025年12月24日
    000
  • 为什么 CSS mask 属性未请求指定图片?

    解决 css mask 属性未请求图片的问题 在使用 css mask 属性时,指定了图片地址,但网络面板显示未请求获取该图片,这可能是由于浏览器兼容性问题造成的。 问题 如下代码所示: 立即学习“前端免费学习笔记(深入)”; icon [data-icon=”cloud”] { –icon-cl…

    2025年12月24日
    200
  • 如何利用 CSS 选中激活标签并影响相邻元素的样式?

    如何利用 css 选中激活标签并影响相邻元素? 为了实现激活标签影响相邻元素的样式需求,可以通过 :has 选择器来实现。以下是如何具体操作: 对于激活标签相邻后的元素,可以在 css 中使用以下代码进行设置: li:has(+li.active) { border-radius: 0 0 10px…

    2025年12月24日
    100
  • 如何模拟Windows 10 设置界面中的鼠标悬浮放大效果?

    win10设置界面的鼠标移动显示周边的样式(探照灯效果)的实现方式 在windows设置界面的鼠标悬浮效果中,光标周围会显示一个放大区域。在前端开发中,可以通过多种方式实现类似的效果。 使用css 使用css的transform和box-shadow属性。通过将transform: scale(1.…

    2025年12月24日
    200
  • 为什么我的 Safari 自定义样式表在百度页面上失效了?

    为什么在 Safari 中自定义样式表未能正常工作? 在 Safari 的偏好设置中设置自定义样式表后,您对其进行测试却发现效果不同。在您自己的网页中,样式有效,而在百度页面中却失效。 造成这种情况的原因是,第一个访问的项目使用了文件协议,可以访问本地目录中的图片文件。而第二个访问的百度使用了 ht…

    2025年12月24日
    000
  • 如何用前端实现 Windows 10 设置界面的鼠标移动探照灯效果?

    如何在前端实现 Windows 10 设置界面中的鼠标移动探照灯效果 想要在前端开发中实现 Windows 10 设置界面中类似的鼠标移动探照灯效果,可以通过以下途径: CSS 解决方案 DEMO 1: Windows 10 网格悬停效果:https://codepen.io/tr4553r7/pe…

    2025年12月24日
    000
  • 使用CSS mask属性指定图片URL时,为什么浏览器无法加载图片?

    css mask属性未能加载图片的解决方法 使用css mask属性指定图片url时,如示例中所示: mask: url(“https://api.iconify.design/mdi:apple-icloud.svg”) center / contain no-repeat; 但是,在网络面板中却…

    2025年12月24日
    000
  • 如何用CSS Paint API为网页元素添加时尚的斑马线边框?

    为元素添加时尚的斑马线边框 在网页设计中,有时我们需要添加时尚的边框来提升元素的视觉效果。其中,斑马线边框是一种既醒目又别致的设计元素。 实现斜向斑马线边框 要实现斜向斑马线间隔圆环,我们可以使用css paint api。该api提供了强大的功能,可以让我们在元素上绘制复杂的图形。 立即学习“前端…

    2025年12月24日
    000
  • 图片如何不撑高父容器?

    如何让图片不撑高父容器? 当父容器包含不同高度的子元素时,父容器的高度通常会被最高元素撑开。如果你希望父容器的高度由文本内容撑开,避免图片对其产生影响,可以通过以下 css 解决方法: 绝对定位元素: .child-image { position: absolute; top: 0; left: …

    2025年12月24日
    000
  • 为什么自定义样式表在 Safari 中访问百度页面时无法生效?

    自定义样式表在 safari 中失效的原因 用户尝试在 safari 偏好设置中添加自定义样式表,代码如下: body { background-image: url(“/users/luxury/desktop/wallhaven-o5762l.png”) !important;} 测试后发现,在…

    2025年12月24日
    000
  • CSS 帮助

    我正在尝试将文本附加到棕色框的左侧。我不能。我不知道代码有什么问题。请帮助我。 css .hero { position: relative; bottom: 80px; display: flex; justify-content: left; align-items: start; color:…

    2025年12月24日 好文分享
    200
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信