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

Shell学习之路-(02-文件的权限修改)_第1张图片
题图: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-文件的权限修改))