Linux 文件权限chmod命令

概述

Android开发的过程中,经常需要从手机中导出文件(非存储卡中的,比如/data/data/包名/databases/下的数据库文件,手机需要root),会出现permission denied或remote object “*” does not exist的错误,如下图所示:
这里写图片描述

permission denied错误,有些时候,是由于手机没有root导致的,手机如何root,还请自行去百度。

本文的内容,主要是讲解如何修改文件的权限,达到手机root后,随心所欲操作文件的目的。

查看手机文件权限

查看文件权限的命令为:ll或者ls -l。
Linux 文件权限chmod命令_第1张图片

ll命令和ls -l命令有什么区别呢?
猿友提供的答案:ll会列出该文件下的所有文件信息,包括隐藏的文件,而ls -l只列出显式文件。
这个区别,本人并未验证。

Linux文件权限详细解读

看到ll命令显示出来的文件信息,你也许会很懵逼,我刚刚接触的时候,也很懵逼。没关系,我们来一点一点的解读。

我们先看最左边的文件信息:
Linux 文件权限chmod命令_第2张图片

图片最左边红框中的内容,就是Linux系统下文件权限的表示方法,那它们都代表什么意思呢?
Linux文件权限信息共有10位,分为4段。比如第一行中的“drwxr-xr-x”。
第一段:第1位,表示文件类型。
-为:表示文件;
d为:表示文件夹;
l为:表示链接文件,可以理解为 windows中的快捷方式(link file);
b为:表示里面可以供存储周边设备;
c为:表示里面为一次性读取装置。

第二段:第2,3,4位,拥有者具有的权限。
类似于windows中的所有者权限,比如 administrator 对文件具有的权限。
比如第一行中的“drwxr-xr-x“,表示拥有者具有可读(r)、可写(w)、可执行(x)的权限。

第三段:第5,6,7位,属于这个组的成员具有的权限。
类似于windows中的组权限,比如administrators组,属于这个组的成员对于文件的权限。
比如第一行中的“drwxr-xr-x“,表示这个组的成员具有可读(r)、不可写(-)、可执行(x)的权限。

第四段:第8,9,10位,其他成员具有的权限。
类似于windows中的anyone一样,就是说所有人对这个文件都会有一个怎样的权限。
比如第一行中的“drwxr-xr-x“,表示其他成员具有可读(r)、不可写(-)、可执行(x)的权限。

之后的内容,就比较容易看懂了。
Linux 文件权限chmod命令_第3张图片
分别为所有者、组、(字节数,因为这里都是文件夹,所以没有显示)、文件最后修改时间、文件名。

补充

之前的图片中,我用su命令进入root模式后,如下图所示:
这里写图片描述

写文章时,验证这些命令所用的手机为魅族MX 4 Pro,系统自带启用root权限功能。但是启用之后,用su命令进入root,其实并不是真正的root。
在这种模式下,我想进入/data/data目录,查看文件,都是没有权限的。
所以,我又用360超级root工具,对手机进行了root(在没开启手机root之前,直接用360超级root工具,root很多次都没有成功),很快就root成功了。
以下是真正root后进入su模式的截图:
这里写图片描述

chmod命令

现在,就要用chmod命令来改变文件的权限了。

Linux下,标准的chmod语法如下:
chmod [who] [+ | - | =] [mode] 文件名

命令中各选项的含义为
u 表示“用户(user)”,即文件或目录的所有者。
g 表示“同组(group)用户”,即与文件属主有相同组ID的所有用户。
o 表示“其他(others)用户”。
a 表示“所有(all)用户”,也就是包括了u、g、o,它是系统默认值。

操作符号可以是:
+ 添加某个权限。
- 取消某个权限。
= 重新分配权限。

设置mode所表示的权限可用下述字母的任意组合:
r 可读。
w 可写。
x 可执行。

比如,data文件的权限如下。权限表示,所有者和同组用户,对data文件夹拥有可读、可写、可执行权限。其他用户对data文件夹拥有可执行权限,但不可读,不可写。
这里写图片描述

我们来用chmod命令改变data文件夹的权限,让其他用户对data文件夹也可读、可写、可执行权限。命令如下
chmod o +rwx /data

运行命令,却并未如愿,提示bad mode:
这里写图片描述

为什么会提示bad mode呢?
这是因为Android系统的限制,Android系统中并不支持+rwx这种命令格式。

那怎么办呢?
我们用另一种格式,数字格式。
什么是数字格式呢?就是rwx用数字代替。
r ———-4
w ———2
x ———-1
- ———-0

chmod o +rwx /data 命令替换成数字模式,是什么样子呢?
chmod 777 /data
比较2中模式的命令,我们发现,出了rwx替换成了数字之外,数字模式中少了设置的用户o。

那数字模式中,怎么表示用户呢?
数字模式中的数字,就表示了用户。
比如chmod 777 /data
第一个7,表示所有者u;
第二个7,表示用户组g;
第三个7,表示其他用户o。

那数字模式中,数字怎么确定呢?
看权限和数字的对应关系。
比如, 不可读(-)、不可写(-)、不可执行(-) :0+0+0 = 0;
比如+x, 不可读(-)、不可写(-)、不可执行(x) :0+0+1 = 1;
比如+w, 不可读(-)、不可写(w)、不可执行(-) :0+2+0 = 2;
比如+wx, 不可读(-)、不可写(w)、不可执行(x) :0+2+1 = 3;
比如+r, 不可读(r)、不可写(-)、不可执行(-) :4+0+0 = 4;
比如+rx, 不可读(r)、不可写(-)、不可执行(x) :4+0+1 = 5;
比如+rw, 不可读(r)、不可写(w)、不可执行(-) :4+2+0 = 6;
比如+rwx, 不可读(r)、不可写(w)、不可执行(x) :4+2+1 = 7;
仔细观察,应该不难发现,其实就是rwx的二进制位操作,为0,表示无权限,为1,表示有权限。rwx对应的十进制,就是所需的数字。

到这里,我们常见的以下的一些权限就很容易都明白了:
-rw——-(600) 只有所有者才有读和写的权限
-rw-r–r– (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限
-rwx——(700) 只有所有者才有读,写,执行的权限
-rwxr-xr-x (755) 只有所有者才有读,写,执行的权限,组群和其他人只有读和执行的权限
-rwx–x–x (711) 只有所有者才有读,写,执行的权限,组群和其他人只有执行的权限
-rw-rw-rw- (666) 每个人都有读写的权限
-rwxrwxrwx (777) 每个人都有读写和执行的权限

再看一下chmod命令的说明:
这里写图片描述
有一个-R或者–recursive参数,这个参数标示:递归处理,将指令目录下的所有文件及子目录一并处理。

以上内容都理解了之后,如果发现文件访问失败,或者用adb push、adb pull命令失败,可以去看看,是不是文件权限问题,如果是权限问题,那更改文件权限就是了。

你可能感兴趣的:(android)