应用文件分享是应用之间通过分享URI(Uniform Resource Identifier)或文件描述符FD(File Descriptor)的方式,进行文件共享的过程。
-
基于URI分享方式,应用可分享单个文件,通过 ohos.app.ability.wantConstant 的wantConstant.Flags接口以只读或读写权限授权给其他应用。应用可通过 ohos.file.fs 的open接口打开URI,并进行读写操作。当前仅支持临时授权,分享给其他应用的文件在被分享应用退出时权限被收回。
-
基于FD分享方式,应用可分享单个文件,通过ohos.file.fs的open接口以指定权限授权给其他应用。应用从Want中解析拿到FD后可通过ohos.file.fs的读写接口对文件进行读写。
由于FD分享的文件关闭FD后,无法再打开分享文件,因此不推荐使用,本文重点介绍基于URI 分享文件给其他应用 或 使用其他应用分享的文件 。
应用可分享目录
沙箱路径 | 物理路径 | 说明 |
---|---|---|
/data/storage/el1/base | /data/app/el1//base/ | 应用el1级别加密数据目录 |
/data/storage/el2/base | /data/app/el2//base/ | 应用el2级别加密数据目录 |
/data/storage/el2/distributedfiles | /mnt/hmdfs//account/device_view//data/ | 应用el2加密级别有帐号分布式数据融合目录 |
文件URI规范
文件URI的格式为:
格式为file:///
-
file:文件URI的标志。
-
bundleName:该文件资源的属主。
-
path:文件资源在应用沙箱中的路径。
分享文件给其他应用
在分享文件给其他应用前,开发者需要先 获取应用文件路径 。
- 获取文件在应用沙箱中的路径,并转换为文件URI。
import { UIAbility } from '@kit.AbilityKit';
import { fileUri } from '@kit.CoreFileKit';
import { window } from '@kit.ArkUI';
export default class EntryAbility extends UIAbility {
onWindowStageCreate(windowStage: window.WindowStage) {
// 获取文件的沙箱路径
let pathInSandbox = this.context.filesDir + "/test1.txt";
// 将沙箱路径转换为uri
let uri = fileUri.getUriFromPath(pathInSandbox);
// 获取的uri为"file://com.example.demo/data/storage/el2/base/files/tes