美文网首页路由联盟程序员我用 Linux
Shell学习之路-(02-文件的权限修改)

Shell学习之路-(02-文件的权限修改)

作者: Creator_Ly | 来源:发表于2017-03-22 10:59 被阅读109次
    题图:gratisography

    文件的权限修改

    1 分析

    新建两个测试脚本test_1.sh和test_2.sh,内容大概如下就行:

    #!/bin/sh
    
    echo "test_1
    

    发现这时如果直接输入./test_1.sh是没办法执行该脚本的(输入时也没办法使用Tab键进行补全),会提示权限限制,如下:

    linye@ly:~/test_scripts$ ./test_1.sh
    -bash: ./test_1.sh: Permission denied
    

    通过llls -la查看文件的权限,如下:

    linye@ly:~/test_scripts$ ll
    drwxrwxr-x  2 linye linye 4096 Mar 17 14:04 ./
    drwxr-xr-x 49 linye linye 4096 Mar 17 14:04 ../
    -rw-rw-r--  1 linye linye   25 Mar 17 14:01 test_1.sh
    -rw-rw-r--  1 linye linye   26 Mar 17 14:01 test_2.sh
    

    一般只需要关注第一列即可,第一列一共有十个字符,第一个字符为d表示该对象对一个文件夹,为-表示该对象为一个文件。

    后面九个字符分为3-3-3,三组每一组三个字符,三个字符分别代表读、写、执行,如果该位置有对应的字符说明有该权限,如果为-,则表示没有该权限,而三组从左至右分别代表为文件属主、与属主同组的用户、系统中其他用户。

    所以新创建的脚本权限为-rw-rw-r--,即可读可写但是没有可执行的权限,所以上面输入./test_1.sh无法执行。

    2 修改

    修改文件的权限有很多种方式/格式,这边就只介绍几个经常使用的指令即可。

    2.1 直接法

    用户的表达有如下几个:

    • u 表示“用户(user)”,即文件或目录的所有者。
    • g 表示“同组(group)用户”,即和文件属主有相同组ID的所有用户。
    • o 表示“其他(others)用户”。
    • a 表示“所有(all)用户”。

    操作额表达有如下几个:

    • r 可读。
    • w 可写。
    • x 可执行。

    所以我们可以使用指令chmod u=rwx,g=rwx,o=rwx test_1.sh来修改权限,如下:

    linye@ly:~/test_scripts$ chmod u=rwx,g=rwx,o=rwx test_1.sh
    linye@ly:~/test_scripts$ ls -la
    total 16
    drwxrwxr-x  2 linye linye 4096 Mar 17 14:04 .
    drwxr-xr-x 49 linye linye 4096 Mar 17 14:04 ..
    -rwxrwxrwx  1 linye linye   25 Mar 17 14:01 test_1.sh
    -rw-rw-r--  1 linye linye   26 Mar 17 14:04 test_2.sh
    

    同理我们可以使用chmod a=rwx test_2.sh来修改权限,如下:

    linye@ly:~/test_scripts$ chmod a=rwx test_2.sh
    linye@ly:~/test_scripts$ ls -la
    total 16
    drwxrwxr-x  2 linye linye 4096 Mar 17 14:04 .
    drwxr-xr-x 49 linye linye 4096 Mar 17 14:04 ..
    -rwxrwxrwx  1 linye linye   25 Mar 17 14:01 test_1.sh
    -rwxrwxrwx  1 linye linye   26 Mar 17 14:04 test_2.sh
    

    2.2 数值法

    数值法即将rwx三个操作转化成三个二进制数值即可,如数字7代表二进制的111,即可读可写可执行;数字5代表二进制101,即可读不可写可执行。

    所以可以有如下操作:

    linye@ly:~/test_scripts$ chmod 543 test_1.sh
    linye@ly:~/test_scripts$ ls -la
    total 16
    drwxrwxr-x  2 linye linye 4096 Mar 17 14:04 .
    drwxr-xr-x 49 linye linye 4096 Mar 17 14:04 ..
    -r-xr---wx  1 linye linye   25 Mar 17 14:01 test_1.sh
    -rwxrwxrwx  1 linye linye   26 Mar 17 14:04 test_2.sh
    

    输入了543三个数值,分别对应三个用户的权限,即101、100、011。

    当然还有很多其他方法,这边就不过多介绍了,够用就行。

    将test_2.sh设置成可执行后,就可以通过./test_2.sh直接执行了

    linye@ly:~/test_scripts$ ./test_2.sh
    test_2
    

    还有一种是不用修改权限,直接使用sh test_2.sh,这时候就跟文件头部的#! /bin/sh无关了。

    文件的权限修改的分析就到这边,有感悟时会持续会更新。

    注:以上内容来自C语言中文网及本人在使用过程的一些理解整理。如有侵权,请及时通知我,我将马上删除,如有错误之处也请指出,进行探讨学习。文章只是起一个引导作用,详细的数据解析内容还请查看Shell相关教程,感谢您的查阅。

    相关文章

      网友评论

        本文标题:Shell学习之路-(02-文件的权限修改)

        本文链接:https://www.haomeiwen.com/subject/avwwnttx.html