关于文件权限的摘记
在unix中, 文件权限是一个很重要的特征, 决定了对一个文件的读, 写, 执行操作是否可以进行, 基础的相关知识就不重复说明, 在APUE中有如下摘要:
- 对于\ 目录\ 的读权限和执行权限的意义是不同的. 读权限允许我们读目录, 获得在该目录中所有文件名的列表. 档一个目录是我们要访问文件的路径名的一个组成部分时, 对该目录的执行权限是我们可以通过该目录(也就是搜索该目录, 寻找一个特定的文件名). 例如:
.. code:: bash
$ mkdir -p test/tmp # 创建目录
$ touch test/tmp/touchfile # touch文件
$ chmod a-x test # 去除执行权限
$ ls -l test/ # 列出test文件夹下文件
$ ls: cannot access test/tmp: Permission denied
total 0
d????????? ? ? ? ? ? tmp
$ ls -l test/tmp # 列出下一级目录内容
ls: cannot access test/tmp: Permission denied
由于没有执行权限,执行\ ls -l test/
\ 时可以列出\ test
\ 目录下的文件,
也就是能获得test目录中所有文件名的列表, 但是无法获得其他信息.
更无法通过该目录列出下一级目录的内容.
- 对于一个文件的读权限决定了我们能否打开该文件进行读操作.
- 对于一个文件的写权限决定了我们是否能够打开该文件进行写操作.
- 在一个目录中创建一个新文件, 前提是必须对该目录有写和执行权限.
- 想要删除一个现有文件, 则必须对包含该文件的目录具有写权限和执行权限.
更多文章
本站热门
- socks5 协议详解
- zerotier简明教程
- 搞定面试中的系统设计题
- 用peewee代替SQLAlchemy
- frp 源码阅读与分析(一):流程和概念
- Golang(Go语言)中实现典型的fork调用
- DNSCrypt简明教程
- 一个Gunicorn worker数量引发的血案
- Golang validator使用教程
- Docker组件介绍(一):runc和containerd
- Docker组件介绍(二):shim, docker-init和docker-proxy
- 使用Go语言实现一个异步任务框架
- 协程(coroutine)简介 - 什么是协程?
- SQLAlchemy简明教程
- Go Module 简明教程