Android SDK 工具会将您的代码连同任何数据和资源文件编译成一个 APK(Android 软件包),即带有 .apk 后缀的归档文件。
每个 Android 应用都处于各自的安全沙盒中,并受以下 Android 安全功能的保护:
- Android 操作系统是一种多用户 Linux 系统,其中的每个应用都是一个不同的用户;
内容解析:
1. 多用户系统:Android 是基于 Linux 内核构建的操作系统,而 Linux 内核本身就是一个多用户系统。多用户系统意味着操作系统可以同时支持多个用户,并且每个用户都可以拥有自己的独立环境和资源。
2. 每个应用是一个不同的用户:在 Android 中,每个应用都在操作系统层面上被视为一个独立的用户。尽管这些用户并非传统意义上的用户账户,但在 Android 的安全模型中,每个应用都被隔离在自己的沙箱环境中,无法直接访问其他应用的数据或资源。 - 默认情况下,系统会为每个应用分配一个唯一的 Linux 用户 ID(该 ID 仅由系统使用,应用并不知晓)。系统会为应用中的所有文件设置权限,使得只有分配给该应用的用户 ID 才能访问这些文件;
内容解析:
在 Linux 系统中,用户身份的管理是通过唯一的 User ID(UID)来实现的。UID 是一个数字标识符,用于标识和区分不同的用户。
- 用户和用户组:
在 Linux 中,每个用户都有一个唯一的 UID。同时,用户还可以分配到一个或多个用户组,每个用户组也有一个唯一的 Group ID(GID)。这些 UID 和 GID 在系统中用于身份验证和访问控制。 - 文件的所有者和权限:
每个文件在 Linux 中都有一个所有者(Owner),可以通过 UID 来标识。文件的所有者对文件具有特殊的权限,即该用户可以对文件进行读取、写入和执行操作。文件还分别属于一个用户组和其他用户,对应的权限也可以分别设置。 - 文件权限标志:
- 读取权限(Read):对应为 "r",表示用户可以读取文件内容。
- 写入权限(Write):对应为 "w",表示用户可以修改文件内容。
- 执行权限(Execute):对应为 "x",表示用户可以执行文件(如果是可执行文件)。
- 每个进程都拥有自己的虚拟机 (VM),因此应用代码独立于其他应用而运行。
- 默认情况下,每个应用都在其自己的 Linux 进程内运行。Android 系统会在需要执行任何应用组件时启动该进程,然后当不再需要该进程或系统必须为其他应用恢复内存时,其便会关闭该进程。
Android 系统实现了最小权限原则。换言之,默认情况下,每个应用只能访问执行其工作所需的组件,而不能访问其他组件。这样便能创建非常安全的环境,在此环境中,应用无法访问其未获得权限的系统部分。不过,应用仍可通过一些途径与其他应用共享数据以及访问系统服务:
- 可以安排两个应用共享同一 Linux 用户 ID,在此情况下,二者便能访问彼此的文件。为节省系统资源,也可安排拥有相同用户 ID 的应用在同一 Linux 进程中运行,并共享同一 VM。应用还必须使用相同的证书进行签名。
1. 配置相同的用户 ID:
在 Android 的应用清单文件(AndroidManifest.xml)中,为应用A和应用B指定相同的用户 ID。可以使用 android:sharedUserId 属性来设置相同的用户 ID。
2. 共享进程(Shared Process):
在应用清单文件中,可以使用 android:process 属性将应用A和应用B配置为在同一个进程中运行 - 应用可以请求访问设备数据(如用户的联系人、短信消息、可装载存储装置(SD 卡)、相机、蓝牙等)的权限。用户必须明确授予这些权限。