1# 应用沙箱目录 2 3应用沙箱是一种以安全防护为目的的隔离机制,避免数据受到恶意路径穿越访问。在这种沙箱的保护机制下,应用可见的目录范围即为“应用沙箱目录”。 4 5- 对于每个应用,系统会在内部存储空间映射出一个专属的“应用沙箱目录”,它是“[应用文件目录](#应用文件目录与应用文件路径)”与一部分系统文件(应用运行必需的少量系统文件)所在的目录组成的集合。 6 7- 应用沙箱限制了应用可见的数据范围。在“应用沙箱目录”中,应用默认仅能看到自己的应用文件以及少量的系统文件(应用运行必需的少量系统文件)。在全量挂载的设备平台上,文件管理应用可查看其他应用存放在el2/base下的数据。 8 9- 应用可以在“应用文件目录”下保存和处理自己的应用文件;系统文件及其目录对于应用是只读的;而应用若需访问[用户文件](user-file-overview.md),则需要通过特定API同时经过用户的相应授权才能进行。 10 11下图展示了应用沙箱下,应用可访问的文件范围和方式。 12 13**图1** 应用沙箱文件访问关系图 14 15 16## 应用沙箱目录与应用沙箱路径 17 18在应用沙箱保护机制下,应用无法获知除自身应用文件目录之外的其他应用或用户的数据目录位置及存在。同时,所有应用的目录可见范围均经过权限隔离与文件路径挂载隔离,形成了独立的路径视图,屏蔽了实际物理路径: 19 20- 如下图所示,在普通应用(也称三方应用)视角下,不仅可见的目录与文件数量限制了范围,并且可见的目录与文件路径也与系统进程等其他进程看到的不同。我们将普通应用视角下看到的“应用沙箱目录”下某个文件或某个具体目录的路径,称为“应用沙箱路径”。 21 22<!--RP1--> 23- 开发者的hdc shell环境等效于系统进程视角,因此“应用沙箱路径”与使用hdc工具调试时看到的真实物理路径不同。具体对应关系请参见[应用沙箱路径和真实物理路径的对应关系](#应用沙箱路径和真实物理路径的对应关系)。 24<!--RP1End--> 25 26- 实际物理路径与沙箱路径并非1:1的映射关系,沙箱路径总是少于系统进程视角可见的物理路径。部分调试进程视角下的物理路径在对应的应用沙箱目录下没有对应路径。 27 28**图2** 应用沙箱路径(不同权限与角色的进程下可见的文件路径不同) 29 30 31## 应用文件目录与应用文件路径 32 33如前文所述,“应用沙箱目录”内分为两类:应用文件目录和系统文件目录。 34 35系统文件目录对应用的可见范围由OpenHarmony系统预置,开发者无需关注。 36 37在此主要介绍应用文件目录,如下图所示。应用文件目录下的文件或目录路径称为应用文件路径。各文件路径具有不同的属性和特征。 38 39**图3** 应用文件目录结构图 40 41 42> **说明:** 43> 44> - 禁止直接使用上图中四级目录之前的目录名组成的路径字符串,否则可能导致后续应用版本因应用文件路径变化导致不兼容问题。 45> - 应通过Context属性获取应用文件路径,包括但不限于上图中绿色背景的路径。 Context上下文获取及上述应用文件路径的获取,详见[应用上下文Context](../application-models/application-context-stage.md)。 46 471. 一级目录data/:应用文件目录。 48 492. 二级目录storage/:应用持久化文件目录。 50 513. 三级目录el1/~el5/:不同文件加密类型。 52 53 EL1(Encryption Level 1): 54 - 保护设备上所有文件的基础安全能力。设备开机后,用户无需完成身份验证即可访问EL1保护的文件。除非有特殊需求,否则不建议使用此方法。 55 - 如果直接窃取设备存储介质上的密文,攻击者无法脱机进行解密。 56 57 EL2(Encryption Level 2): 58 - 在EL1的基础上,增加首次认证后的文件保护能力。设备开机后,用户在通过首次认证后,通过EL2能力保护的文件才能被访问。此后只要设备没有关机,通过EL2能力保护的文件一直可被访问。推荐应用默认使用该方式。 59 - 如果在关机后丢失手机,攻击者无法读取EL2保护的文件。 60 61 EL3(Encryption Level 3): 62 - 与EL4整体能力类似,但和EL4的区别是,在锁屏下可创建新的文件,但无法读取。如无特殊必要,无需使用该方式。 63 64 EL4(Encryption Level 4): 65 - 在EL2的基础上,增加设备锁屏时的文件保护能力。在用户锁屏时,通过EL4能力保护的数据将无法被访问。如无特殊必要,无需使用该方式。 66 - 如果设备在锁屏状态下被盗,攻击者无法读取EL4保护的文件。 67 68 EL5(Encryption Level 5): 69 - 在EL2的基础上,增加设备锁屏时的文件保护能力。在用户锁屏后,满足一定条件时,通过EL5能力保护的数据将无法被访问,但可以继续创建和读写新的文件。如无特殊必要,无需使用该方式。 70 - 默认情况下不会生成EL5的相关目录,应用若需要使用EL5目录,则需要配置访问E类加密数据库的权限。具体配置方法详见[E类加密数据库的使用](../database/encrypted_estore_guidelines.md)。 71 72 > **说明:** 73 > 74 > 应用如无特殊需要,应将数据存放在el2加密目录下,以尽可能保证数据安全。但是对于某些场景,一些应用文件需要在用户首次认证前就可被访问,例如时钟、闹铃、壁纸等,此时应用需要将这些文件存放到设备级加密区(el1)。 75 > 76 > 开发者可通过监听[COMMON_EVENT_USER_UNLOCKED](../reference/apis-basic-services-kit/common_event/commonEventManager-definitions.md#common_event_user_unlocked)事件感知当前用户首次认证完成。 77 > 78 > 切换应用文件加密类型目录的方法请参见[获取和修改加密分区](../application-models/application-context-stage.md#获取和修改加密分区)。 79 804. 四级、五级目录: 81 通过ApplicationContext获取distributedfiles目录或base下的files、cache、preferences、temp等目录的路径,应用全局信息存放在这些目录下。 82 83 通过UIAbilityContext、AbilityStageContext、ExtensionContext可以获取HAP级别应用文件路径。HAP信息可以存放在这些目录下,存放在此目录的文件会跟随HAP的卸载而删除,不会影响App级别目录下的文件。在开发态,一个应用包含一个或者多个HAP,详见[Stage模型应用程序包结构](../quick-start/application-package-structure-stage.md)。 84 85 应用文件路径具体说明及生命周期如下表所示。 86 87 **表1** 应用文件路径详细说明 88 89 | 目录名 | Context属性名称 | 类型 | 说明 | 90 | -------- | -------- | -------- | -------- | 91 | bundle | bundleCodeDir | 安装文件路径 | 应用安装后的App的HAP资源包所在目录;随应用卸载而清理。<br>不能通过拼接路径访问资源文件,应使用[资源管理接口](../reference/apis-localization-kit/js-apis-resource-manager.md)访问资源。<br>可以用于存储应用的代码资源数据,主要包括应用安装的HAP资源包、可重复使用的库文件以及插件资源等。此路径下存储的代码资源数据可以被用于动态加载。| 92 | base | NA | 本设备文件路径 | 应用在本设备上存放持久化数据的目录,子目录包含files/、cache/、temp/和haps/;随应用卸载而清理。 | 93 | database | databaseDir | 数据库路径 | 应用在el2加密条件下存放通过分布式数据库服务操作的文件目录;随应用卸载而清理。<br>仅用于保存应用的私有数据库数据,主要包括数据库文件等。此路径下仅适用于存储分布式数据库相关文件数据。 | 94 | distributedfiles | distributedFilesDir | 分布式文件路径 | 应用在el2加密条件下存放分布式文件的目录,应用将文件放入该目录可分布式跨设备直接访问;随应用卸载而清理。<br>可以用于保存应用分布式场景下的数据,主要包括应用多设备共享文件、应用多设备备份文件、应用多设备群组协助文件。此路径下存储这些数据,使得应用更加适合多设备使用场景。 | 95 | files | filesDir | 应用通用文件路径 | 应用在本设备内部存储上通用的存放默认长期保存的文件路径;随应用卸载而清理。<br>可以用于保存应用的任何私有数据,主要包括用户持久性文件、图片、媒体文件以及日志文件等。此路径下存储这些数据,使得数据保持私有、安全且持久有效。 | 96 | cache | cacheDir | 应用缓存文件路径 | 应用在本设备内部存储上用于缓存下载的文件或可重新生成的缓存文件的路径,应用cache目录大小超过配额或者系统空间达到一定条件,自动触发清理该目录下文件;用户通过系统空间管理类应用也可能触发清理该目录。应用需判断文件是否仍存在,决策是否需重新缓存该文件;随应用卸载而清理。<br>可以用于保存应用的缓存数据,主要包括离线数据、图片缓存、数据库备份以及临时文件等。此路径下存储的数据可能会被系统自动清理,因此不要存储重要数据。 | 97 | preferences | preferencesDir | 应用首选项文件路径 | 应用在本设备内部存储上通过数据库API存储配置类或首选项的目录;随应用卸载而清理。详见[通过用户首选项实现数据持久化](../database/data-persistence-by-preferences.md)。 <br>可以用于保存应用的首选项数据,主要包括应用首选项文件以及配置文件等。此路径下仅适用于存储小量数据。| 98 | temp | tempDir | 应用临时文件路径 | 应用在本设备内部存储上仅在应用运行期间产生和需要的文件,应用退出后即清理。<br>可以用于保存应用的临时生成的数据,主要包括数据库缓存、图片缓存、临时日志文件、以及下载的应用安装包文件等。此路径下存储使用后即可删除的数据。 | 99 100## 应用沙箱路径和真实物理路径的对应关系 101 102在应用沙箱路径下读写文件,经过映射转换,实际读写的是真实物理路径中的应用文件,应用沙箱路径与真实物理路径对应关系如下表所示。 103 104其中<USERID>为当前用户ID,从100开始递增,<EXTENSIONPATH>为moduleName-extensionName。应用是否以Extension独立沙箱运行可参考[ExtensionAbility组件](../application-models/extensionability-overview.md)。 105 106| 应用沙箱路径 | 物理路径 | 107| -------- | -------- | 108| /data/storage/el1/bundle | 应用安装包目录:<br> /data/app/el1/bundle/public/<PACKAGENAME> | 109| /data/storage/el1/base | 应用el1级别加密数据目录:<br> - 非独立沙箱运行的应用:/data/app/el1/<USERID>/base/<PACKAGENAME><br> - 以独立沙箱运行的Extension应用: /data/app/el1/<USERID>/base/+extension-<EXTENSIONPATH>+<PACKAGENAME> | 110| /data/storage/el2/base | 应用el2级别加密数据目录:<br> - 非独立沙箱运行的应用:/data/app/el2/<USERID>/base/<PACKAGENAME><br> - 以独立沙箱运行的Extension应用: /data/app/el2/<USERID>/base/+extension-<EXTENSIONPATH>+<PACKAGENAME> | 111| /data/storage/el1/database | 应用el1级别加密数据库目录:<br> - 非独立沙箱运行的应用:/data/app/el1/<USERID>/database/<PACKAGENAME><br> - 以独立沙箱运行的Extension应用:/data/app/el1/<USERID>/database/+extension-<EXTENSIONPATH>+<PACKAGENAME> | 112| /data/storage/el2/database | 应用el2级别加密数据库目录:<br> - 非独立沙箱运行的应用:/data/app/el2/<USERID>/database/<PACKAGENAME><br> - 以独立沙箱运行的Extension应用:/data/app/el2/<USERID>/database/+extension-<EXTENSIONPATH>+<PACKAGENAME> | 113| /data/storage/el2/distributedfiles | /mnt/hmdfs/<USERID>/account/merge_view/data/<PACKAGENAME> | 应用el2加密级别有账号分布式数据融合目录 | 114