1、取得/etiantian文件的权限对应的数字(考试题答案系列)

说明:本文为老男孩linux培训某节课前考试试题及答案分享博文内容的一部分,也是独立成题的,你可以点下面地址查看全部的内容信息。
http://oldboy.blog.51cto.com/2561410/791245答题的思维比做题本身更重要,就是老男孩如何想到的解决问题的思路。

1.如何取得/etiantian文件的权限对应的数字内容,如-rw-r--r-- 644,要求使用命令取得644这样的数字。

解答:


实践过程:

[[email protected] ~]# touch /ett #==>创建测试文件/ett

[[email protected] ~]# stat /ett #==>通过stat命令可以看到文件的数字权限

File: `/ett'

Size: 0Blocks: 0IO Block: 4096regular empty file

Device: 803h/2051dInode: 98211Links: 1

Access: (0644/-rw-r--r--)Uid: (0/root)Gid: (0/root)

Access: 2012-02-20 08:04:24.000000000 +0800

Modify: 2012-02-20 08:04:24.000000000 +0800

Change: 2012-02-20 08:04:24.000000000 +0800

那么我们如何获得这一文件的数字权限呢?

法一过程:(statsedcut

[[email protected] ~]# stat /ett|sed -n '4p'#==>首先通过管道把stat结果传给sed处理取出需要的行。

Access: (0644/-rw-r--r--)Uid: (0/root)Gid: (0/root)

[[email protected] ~]# stat /ett|sed -n '4p'|cut -d "/" -f1 #==>对上面的结果以/线为分割符,然后取第1个字段。这里以斜线分割不是唯一的方法,大家注意下。

Access: (0644

[[email protected] ~]# stat /ett|sed -n '4p'|cut -d "/" -f1|cut -d "(" -f2 #==>这就是法一答案

#==>对上面的结果以(号为分割符,然后取第2个字段,就会得出我们需要的结果。

0644

特别说明:

1)上题中的sed -n '4p'是取结果的第二行的意思,也可以用笨办法head -4|tail -1替代。例:

[[email protected] ~]# stat /ett|head -4|tail -1|cut -d "/" -f1|cut -d "(" -f2 #==>法二答案

0644

2)上题中的cut -d "/" -f1|cut -d "(" -f2部分,也可以用awk,sed等命令替代。如例:

[[email protected] ~]# stat /ett|head -4|tail -1|awk -F "/" '{print $1}'|awk -F "(" '{print $2}'

0644 #==>法三答案,awk法如果大家有不懂的,也不用纠结,本文后面问题里会细讲。

提示::此题考察了大家对stat ,cut,awk,head,tailsed等命令组合用法,有对这些命令还不熟悉的同学,可以分步分批总结下。

注意:敲字符时成对出现的’’,{}内容,最好连续敲完,以免后续落下。

法二过程:(stat

当然还有更简单的方法:

[[email protected] ~]# stat -c %a /ett

644

注意:如何想到法二的思考过程,比答题更重要。当命令结果包含我们需要的内容的时候,我们要想到是否有具体的参数能够一步达到我们需要的结果。

特别说明:

有关stat -c的用法可以通过stat --helpman statinfo stat,这是所有命令的三大帮助杀手锏,必须要掌握了。

[[email protected] ~]# stat --help

Usage: stat [OPTION] FILE... #==>这是语法格式

Display file or file system status.

...省略部分...

-f, --file-systemdisplay file system status instead of file status

-c --format=FORMATuse the specified FORMAT instead of the default;

output a newline after each use of FORMAT

...省略部分...

#==>这是可用的参数,如-c

The valid format sequences for files (without --file-system):

#==>这里是对于文件适用的格式,既-c后接的格式。

%aAccess rights in octal #==>8进制形式显示,即为本文的答案

%AAccess rights in human readable form #==>拓展以人类可读的形式显示权限

%bNumber of blocks allocated (see %B)

%BThe size in bytes of each block reported by %b

%dDevice number in decimal

%DDevice number in hex

%fRaw mode in hex

%FFile type

%gGroup ID of owner

%GGroup name of owner

%hNumber of hard links

%iInode number

%nFile name

%NQuoted file name with dereference if symbolic link

%oI/O block size

%sTotal size, in bytes

...省略部分...

本题的拓展部分

[[email protected] ~]# ls -li /ett

98211 -rw-r--r-- 1 root root 0 Feb 20 08:04 /ett

 

[[email protected] ~]# stat -c %a /ett

644

[[email protected] ~]# stat -c %A /ett #==>获取字符权限

-rw-r--r--

[[email protected] ~]# stat -c %B /ett

512

[[email protected] ~]# stat -c %b /ett

0

[[email protected] ~]# stat -c %i /ett #==>inode信息

98211

[[email protected] ~]# stat -c %n /ett

/ett

[[email protected] ~]# stat -c %o /ett #==>block size

4096

更多相关文章
  • 1.如何取得/etiantian文件的权限对应的数字内容,如-rw-r--r-- 为644,要求使用命令取得644这样的数字.解答:实践过程:[[email protected] ~]# touch /ett #==>创建测试文件/ett[[email protected] ~]# stat /ett #==> ...
  • linux下文件删除的原理精华讲解考试题答案系列
    说明:本文为老男孩linux培训某节课前考试试题及答案分享博文内容的一部分,也是独立成题的,你可以点下面地址查看全部的内容信息.http://oldboy.blog.51cto.com/2561410/7912455.描述linux下文件删除的原理(记时3分钟)<?xml:namespace ...
  • 说明:本文为老男孩linux培训某节课前考试试题及答案分享博文内容的一部分,也是独立成题的,你可以点下面地址查看全部的内容信息.http://oldboy.blog.51cto.com/2561410/791245特别说明:答题的思路技巧可能比做题本身更重要,这也是老男孩特别教导学生的学习方法.7. ...
  • EBB-4、忘记root密码;文件,目录权限
    一.账户操作1.锁定账户:     usermod:     usermod -L afu : 锁定afu用户,该用户将无法登陆系统  注意:需要首先退出root用户,然后登陆afu这个用户,才会出现无法登陆.如果直接在root用户下,              su – afu依然可以切换到该用户 ...
  • 关于RHEL5.1虚拟用户文件删除权限配置答疑
    有网友配置虚拟用户后不能删除文件,提示500 OOPS: bad bool value in config file for哈~细节没注意,我来亲自配置下看看哈~参考:[RHEL5企业级Linux服务攻略]--第6季 Vsftpd服务全攻略之高级配置具体配置如下哈~~1.创建用户数据库(1)创建用户 ...
  • Linux学习:文件特殊权限SUID,SGID,SBIT
    本次记录Linux特殊权限SUID.SGID.SBIT相关知识及使用实例等.由于SUID和SGID涉及到系统安全,所以对它们知识点的掌握尤为重要.关于文件权限的表示方法和解析SUID是Set User ID,SGID是Set Group ID的意思.Linux下可以用ls –l命令来查看文件的权限. ...
  • (s)Suid:当一个文件的属主有s权限,意味着任何用户执行此程序时,其进程的发起着不再是发起者本人,而是以此文件属主的身份来执行此程序.命令chmod u+s file#chmod 4777 file是放在执行权限位的,小写s表示原有属主有执行权限,大写s表示原有属主无执行权限.(s)Sgid:当 ...
  • 一.文件特殊权限s: suid, set uid,属主有s权限,意味着用户在执行此程序时,其进程的属主不再是发起者本人,而是这个程序文件的属主:         s:属主原本有执行权限         S:属主原本无执行权限         chmod u+|-s /path/to/somefile ...
一周排行
  • 学神-RHEL71-15-磁盘加密和RAID配置
    本节所讲内容:xfs和ext性能对比加密磁盘了解:xfs文件系统比ext文件系统的强的方面 ...
  • 配置好Nginx现在在添加一个virtual host (xiaoyuan.com) 配置如下: # vim /etc/nginx/conf.d/virtual.conf  # 在最下面添加 </body> ...
  • 有关于 HandlerSocket 的介绍.性能及其安装,可参考Using SQL as NoSQL.而 PHP extension for interfacing with MySQL Handler Socket ...
  •   不得不承认在这个社会里面每个人都是非常现实的我们没有
  • 沙盒机制--SandBox
            IOS中的沙盒机制(SandBox)是一种安全体系,它规定了应用程序只能在 ...
  •   众所周知,测试部门对于产品的质量问题有着千丝万缕的情怀,自己测试时可谓是绞尽脑汁地寻找每一个可能的bug,交付的时候更是小心翼翼.以前大家喜欢讨论开发和测试之间的恩恩怨怨,今天我来和大家一块儿来探讨一下测试和市场 ...
  • 在qt msvc2010版软件中使用opencv2.4.9进行库函数配置.仅适用于windows下. INCLUDEPATH += $$PWD/../../../opencv/build/include/opencv ...
  • 在我们用WCF传输数据的时候,如果启用默认配置,传输的数据量过大,经常会出这个错误. WCF包含服务端与客户端,所以这个错误可能出现在服务端返回数据给客户端,或客户端传数据给服务端时. 1. 服务端返回数据给客户端报 ...
  • /**2 * 判斷00之間有多少個素數,并輸出這些素數 **/public class Test{ public static void main(String[] args){ int i, j; for ...
  • 最近在修改项目里一些代码违规问题,都是sonar检测出来的...很多问题都是重复出现...于是现在记录一些我觉得比较重要的和容易犯的问题. 日志 比如我用slf4j,那在类里应该这样声明private static ...