具体linux修改文件夹-文件目录权限就是这样设置的了. 1.文件的权限: 文件所属用户 所属用户组 其它用户 权限有: 读:read 数字表示为4:110(4是100);写:write 数字表示为2:10(2是010) ;执行:execute 数字表示为:1(1是001) 所以: 000 001 010 011 100 101 110 111 分别对应是0 1 2 3 4 5 6 7
文件的属主和属组
文件的属主和文件的属组是通过chown命令来定义的,当创建一个文件或者目录的时候,系统默认为创建用户为属主
QUOTE:
# ls ?l httpd.conf
-rwxr-xr-x 1 root admin 348Array0 10月1Array 20:17 httpd.conf
在这里 root 就是文件的属主 admin 文件的属组
格式: chown [所有者]:[属组] file
例: #chown root:admin httpd.conf
----------------------------
文件目录的存取权限
当创建一个文件的时候,系统保存了有关该文件的全部信息,包括:
QUOTE:
文件模式(mode),占Array位
文件类型(type),占一位
文件连接位数(count)
文件属组(group)
文件属主(user)
以字节计的文件长度(size)
文件最后更改时间(time)
文件名(name)
符号连接(s_link)
一 文件类型(type)
Linux支持的文件类型主要包括一下7类,箭头右面的字符就是相应的文件类型位标志:
1、- -------------- 普通文件
2、d -------------- 目录文件
3、l -------------- 符号连接
4、c -------------- 字符设备文件
5、b -------------- 块设备文件
6、命名管道FIFO
7、套接口socket
1、普通文件:就是普通文件,你用’vi myfile’建立的myfile就是普通文件,比如可执行二进制代码 文件、ASCII文本文件、数据文件、配置文件等等
2、目录文件:目录可以理解成放其它文件和其它目录的容器,是一种特殊文件,其内容由目录项组成
3、设备文件:
Linux下的设备文件分为三大类:字符设备、块设备和网络设备
a.字符设备是直接读取的,不使用缓冲区,象串行口、终端等
b.块设备都是通过缓冲区 进行读取的,并且每次只能读取一定数量的块,比如磁盘每次至少要读取一个扇区(如512字节),块设备可以实现随机读写
c.网络设备主要存放在/dev目录下,可以 ls -l 查看下都有什么
---------------------------------
二 文件模式
lrwxr-xr-x 这是该文件的权限位
第一个l
:指定文件类型,表示该文件是一个符号连接文件。(所创建的文件绝大多数都是普通文件或符号链接文件)除去最前面的横杠,一共是Array个字符,他们分别对应Array
个权限位。通过这些权限位,可以设定用户对文件的访问权限。我们把权限位分为3个部分: 文件属主. 属组用户. 其他用户
QUOTE:
前三位:rwx:它的所有者是root,即就是文件所有者,它对这个文件的权限是读写执行
中间三位:r-x:表示admin组中其它用户对这个文件的权限是读和执行
后面位:r-x:就是即不是所有者,也不是属组的对文件的权限是读和执行
通过chmod命令可以改变用户对相应文件的存取权限,权限的算法如下
| 8 7 6 | 5 4 3 | 2 1 0 |
|------|------|------|
| r w x | r - x | r - x |
|------|------|------|
1 1 1 ---1 0 1---1 0 1 = 755
(有权限看作是 1 没有权限看作是 0 这样3组2进制可以算出权限位)
这样我们就可以给文件加我们需要的权限
QUOTE:
# chmod 755 httpd.conf
Chmod命令的格式:chmod [mode] file
在设定权限的时候,还可以按照下面查出与文件属主、属组用户和其他用户所具有的权限相对应的数字,并把它们加起来,就是相应的权限表示可以看出,文件属主、属组用户和其他用户分别所能够具有的最大权限值就是7
QUOTE:
4 0 0 文件属主可读
2 0 0 文件属主可写
1 0 0 文件属主可执行
0 4 0 属组用户可读
0 2 0 属组用户可写
0 1 0 属组用户可执行
0 0 4 其他用户可读
0 0 2 其他用户可写
0 0 1 其他用户可执行
QUOTE:
文件属主:r w x:4 + 2 + 1
属组用户:r w x:4 + 2 + 1
其他用户:r w x:4 + 2 + 1
例:刚才httpd.conf权限位是rwxr-xr-x,那我们根据上面可以算出权限为755
QUOTE:
文件属主:4+2+1=7
属组用户:4+0+1=5
其他用户:4+0+1=5
一般用户默认建立文件权限是664 建立目录权限是775
很多配置文档上都有说给文件加执行权限,然后是
chmod a+x filename 最初不明白什么意思,只是照做,这里简单说下吧
当我们执行# chmod a+x filename 的时候,意思是对此文件所以用户都有执行权限
同样我们执行# chmod a-x filename 是把文件的执行权限去掉,对所有用户
用户的定义:u 所有者 g 属组 o 其它用户 a 所有用户
权限的定义:r 读 w 写 x 执行
例:我们要让aaa.txt文件对它所在组所有用户都有执行权限,那么我们可以执行
QUOTE:
# chmod g+x aaa.txt
----------------------------------
三 连接数
文件的连接计数域表明本系统中共有几个文件目录项的节点和本文件相同,也就是本文件共有几个硬连接
那么对于目录,目录的计算同样表示共有多少个目录项指向此目录
QUOTE:
# ls ?l /home
drwxr-xr-x 5 root root 40Array6 4月 18 16:57 home
大家看到/home目录的属性连接数是5,那么home目录下就包含了3个子目录
为什么不是5个呢,因为还有home本身,和上级目录,也就是当我们在home目录
下执行ls -al 时,看到的 . ..
QUOTE:
.
..
drwx------ 1 hlj hlj
40Array6 4月 15 14:23 aaa
drwxr-xr-x 1 root root
40Array6 4月 16 18:4Array bbb
drwx------ Array pub pub
40Array6 4月 13 21:22 ccc
-----------------------------------
四 文件的属主和属组
这里就是说明本文件是属于那个用户和那个用户组,不同的属主和不同的属组对文件的操作权限也是不同的.
QUOTE:
# ls ?l httpd.conf
-rwxr-xr-x 1 root admin 348Array0 10月1Array 20:17 httpd.conf
如果我们是以aaa用户登陆,而aaa是属于admin组,那么aaa用户对文件的操作权限只有读和执行权限.如果是root用户登陆,那对文件的操作权限就是读,写,执行.
---------------------------------
五 符号连接
符号连接是一种独立的文件类型,它有自己的数据区,但数据区的内容只是一个被它指向的文件的路径名.前面那节的例子说明文件httpd.conf是一个指
向file.txt
文件的符号连接,如果我们执行httpd.conf,系统自动将它指向的文件而不是执行httpd.conf文件本身,也就是说打开的文件是
file.txt.
建立符号连接和建立硬连接一样使用ln命令
格式: ln ?s [源文件] [目标文件]
QUOTE:
# ln ?s /home/file.txt /home/httpd.conf
这里就类似与windows下的快捷方式,目标文件只是做了一个文件路径的指向.
Linux、Fedora、Ubuntu修改文件、文件夹权限的方法差不多。很多人开始接触Linux时都很头痛Linux的文件权限问题。这里告诉大家如何修改Linux文件-文件夹权限。以主文件夹下的一个名为“cc”的文件夹为例。
下面一步一步介绍如何修改权限:
1.打开终端。输入”su”(没有引号)
2.接下来会要你输入密码,输入你的root密码。
3.假设我的文件夹在主目录里,地址为 /var/home/dengchao/cc 。假设我要修改文件权限为777,则在终端输入 chmod 777 /var/home/userid/cc
文件夹的权限就变为了777。
如果是修改文件夹及子文件夹权限可以用 chmod -R 777 /var/home/userid/cc
具体的权限(例如777的含意等)在下面解释下:
1.777有3位,最高位7是设置文件所有者访问权限,第二位是设置群组访问权限,最低位是设置其他人访问权限。
其中每一位的权限用数字来表示。具体有这些权限:
r(Read,读取,权限值为4):对文件而言,具有读取文件内容的权限;对目录来说,具有浏览目 录的权限。
w(Write,写入,权限值为2):对文件而言,具有新增、修改文件内容的权限;对目录来说,具有删除、移动目录内文件的权限。
x(eXecute,执行,权限值为1):对文件而言,具有执行文件的权限;对目录了来说该用户具有进入目录的权限。
2.首先我们来看如何确定单独一位上的权限数值,例如最高位表示文件所有者权限数值,当数字为7时,7用“rwx”表示–{4(r)+2(w)+1(x)=7}–
又如果数值为6,则用“rw-”表示–{4(r)+2(w)+0(x)=6}–,”-”表示不具备权限,这里表示不具备“执行”权限。
假如我们设定其他用户的访问权限为 “r–”,则数值为4+0+0=4
一开始许多初学者会被搞糊涂,其实很简单,我们将rwx看成二进制数,如果有则用1表示,没有则有0表示,那么rwx则可以表示成为:111
而二进制的111就是7。
3.我们再来看下怎么确定3个数位上的权限。假如我们要给一个文件设置权限,具体权限如下:
文件所有者有“读”、“写”、“执行”权限,群组用户有“读”权限,其他用户有“读”权限,则对应的字母表示为”rwx r– r–“,对应的数字为744
一般都是最高位表示文件所有者权限值,第二位表示群组用户权限,最低位表示其他用户权限。
下面来举些例子熟悉下。
权限 | 数值 |
rwx rw- r– | 764 |
rw- r– r– | 644 |
rw- rw- r– | 664 |
具体linux修改文件夹-文件目录权限就是这样设置的了.
1.文件的权限:
文件所属用户 所属用户组 其它用户
权限有:
读:read 数字表示为4:110
写:write 数字表示为2:10
执行:execute 数字表示为:1
0 1 10 11 110 111 1110 1111
0 1 2 3 4 5 6 7
具体解释
1: 1 可执行
2:10 可写
3. 11=10+1 可写可执行
4. 100 可读
5. 101=100+1 可读可执行(5=4+1)
6. 110=100+10 可读可写(6=4+2)
7. 111=100+10+1 可读可写可执行(7=4+2+1)
2.权限的查看:
ls -lmore/less
文件和目录的权限表示,是用rwx这三个字符来代表所有者、用户组和其他用户的权限。有时候,字符似乎过于麻烦,因此还有另外一种方法是以数字来表示权限,而且仅需三个数字。
r: 对应数值4
w: 对应数值2
x:对应数值1
-:对应数值0
数字设定的关键是mode的取值,一开始许多初学者会被搞糊涂,其实很简单,我们将rwx看成二进制数,如果有则有1表示,没有则有0表示,那么rwx r-x r- -则可以表示成为:
111 101 100
再将其每三位转换成为一个十进制数,就是754。
例如,我们想让a.txt这个文件的权限为:
自己 同组用户 其他用户
可读 是 是 是
可写 是 是
可执 行
那么,我们先根据上表得到权限串为:rw-rw-r,那么转换成二进制数就是110 110 100,再每三位转换成为一个十进制数,就得到664,因此我们执行命令:
[root@localhost ~]# chmod 664 a.txt
按照上面的规则,rwx合起来就是4+2+1=7,一个rwxrwxrwx权限全开放的文件,数值表示为777;而完全不开放权限的文件“---------”其数字表示为000。下面举几个例子:
-rwx:等于数字表示700。
-rwxr—r:等于数字表示744。
-rw-rw-r-x:等于数字表示665。
drwx—x—x:等于数字表示711。
drwx:等于数字表示700。
在文本模式下,可执行chmod命令去改变文件和目录的权限。我们先执行ls -l 看看目录内的情况:
[root@localhost ~]# ls -l
总用量 368
-rw-rr 1 root root 12172 8月 15 23:18 conkyrc.sample
drwxr-xr-x 2 root root 48 9月 4 16:32 Desktop
-rrr 1 root root 331844 10月 22 21:08 libfreetype.so.6
drwxr-xr-x 2 root root 48 8月 12 22:25 MyMusic
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth0
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth1
-rwxr-xr-x 1 root root 512 11月 5 08:08 net.lo
drwxr-xr-x 2 root root 48 9月 6 13:06 vmware
可以看到当然文件conkyrc.sample文件的权限是644,然后把这个文件的权限改成777。执行下面命令
[root@localhost ~]# chmod 777 conkyrc.sample
然后ls -l看一下执行后的结果:
[root@localhost ~]# ls -l
总用量 368
-rwxrwxrwx 1 root root 12172 8月 15 23:18 conkyrc.sample
drwxr-xr-x 2 root root 48 9月 4 16:32 Desktop
-rrr 1 root root 331844 10月 22 21:08 libfreetype.so.6
drwxr-xr-x 2 root root 48 8月 12 22:25 MyMusic
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth0
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth1
-rwxr-xr-x 1 root root 512 11月 5 08:08 net.lo
drwxr-xr-x 2 root root 48 9月 6 13:06 vmware
可以看到conkyrc.sample文件的权限已经修改为rwxrwxrwx
如果要加上特殊权限,就必须使用4位数字才能表示。特殊权限的对应数值为:
s或 S (SUID):对应数值4。
s或 S (SGID):对应数值2。
t或 T :对应数值1。
code
用同样的方法修改文件权限就可以了
例如:
code
[root@localhost ~]# chmod 7600 conkyrc.sample
[root@localhost ~]# ls -l
总用量 368
-rwSST 1 root root 12172 8月 15 23:18 conkyrc.sample
drwxr-xr-x 2 root root 48 9月 4 16:32 Desktop
-rrr 1 root root 331844 10月 22 21:08 libfreetype.so.6
drwxr-xr-x 2 root root 48 8月 12 22:25 MyMusic
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth0
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth1
-rwxr-xr-x 1 root root 512 11月 5 08:08 net.lo
drwxr-xr-x 2 root root 48 9月 6 13:06 vmware
加入想一次修改某个目录下所有文件的权限,包括子目录中的文件权限也要修改,要使用参数-R表示启动递归处理。
例如:
[root@localhost ~]# chmod 777 /home/user 注:仅把/home/user目录的权限设置为rwxrwxrwx
[root@localhost ~]# chmod -R 777 /home/user 注:表示将整个/home/user目录与其中的文件和子目录的权限都设置为rwxrwxrwx
文件与目录不仅可以改变权限,其所有权及所属用户组也能修改,和设置权限类似,用户可以通过图形界面来设置,或执行chown命令来修改。
我们先执行ls -l看看目录情况:
[root@localhost ~]# ls -l
总用量 368
-rwxrwxrwx 1 root root 12172 8月 15 23:18 conkyrc.sample
drwxr-xr-x 2 root root 48 9月 4 16:32 Desktop
-rrr 1 root root 331844 10月 22 21:08 libfreetype.so.6
drwxr-xr-x 2 root root 48 8月 12 22:25 MyMusic
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth0
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth1
-rwxr-xr-x 1 root root 512 11月 5 08:08 net.lo
drwxr-xr-x 2 root root 48 9月 6 13:06 vmware
可以看到conkyrc.sample文件的所属用户组为root,所有者为root。
执行下面命令,把conkyrc.sample文件的所有权转移到用户user:
[root@localhost ~]# chown user conkyrc.sample
[root@localhost ~]# ls -l
总用量 368
-rwxrwxrwx 1 user root 12172 8月 15 23:18 conkyrc.sample
drwxr-xr-x 2 root root 48 9月 4 16:32 Desktop
-rrr 1 root root 331844 10月 22 21:08 libfreetype.so.6
drwxr-xr-x 2 root root 48 8月 12 22:25 MyMusic
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth0
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth1
-rwxr-xr-x 1 root root 512 11月 5 08:08 net.lo
drwxr-xr-x 2 root root 48 9月 6 13:06 vmware
要改变所属组,可使用下面命令:
[root@localhost ~]# chown :users conkyrc.sample
[root@localhost ~]# ls -l
总用量 368
-rwxrwxrwx 1 user users 12172 8月 15 23:18 conkyrc.sample
drwxr-xr-x 2 root root 48 9月 4 16:32 Desktop
-rrr 1 root root 331844 10月 22 21:08 libfreetype.so.6
drwxr-xr-x 2 root root 48 8月 12 22:25 MyMusic
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth0
-rwxr-xr-x 1 root root 9776 11月 5 08:08 net.eth1
-rwxr-xr-x 1 root root 512 11月 5 08:08 net.lo
drwxr-xr-x 2 root root 48 9月 6 13:06 vmware
转载于:https://blog.51cto.com/henku/780774