赞
踩
分布式文件系统(hmdfs,HarmonyOS Distributed File System)提供跨设备的文件访问能力,适用于如下场景:
hmdfs在分布式软总线动态组网的基础上,为网络上各个设备结点提供一个全局一致的访问视图,支持开发者通过基础文件系统接口进行读写访问,具有高性能、低延时等优点。
说明
symlink:不支持。
不同设备本身的安全能力差异较大,一些小的嵌入式设备安全能力远弱于平板等设备类型。用户或者应用不同的文件数据有不同安全诉求,例如个人的健康信息和银行卡信息等不期望被弱设备读取。因此,HarmonyOS提供一套完整的数据分级、设备分级标准,并针对不同设备制定不同的数据流转策略,具体规则请参见数据、设备安全分级。
API详细介绍请参见ohos.file.securityLabel。
表1 设置文件数据等级
接口名 | 功能 | 接口类型 | 支持同步 | 支持异步 |
setSecurityLabel | 设置文件安全标签 | 方法 | √ | √ |
getSecurityLabel | 获取文件安全标签 | 方法 | √ | √ |
注意
1. 对于不满足安全等级的文件,跨设备仍然可以看到该文件,但是无权限打开访问该文件。
2. 分布式文件系统的数据等级默认为S3,应用可以主动设置文件的安全等级。
获取通用文件沙箱路径,并设置数据等级标签。示例中的context的获取方式请参见获取UIAbility的上下文信息。
- import securityLabel from '@ohos.file.securityLabel';
-
- // 获取需要设备数据等级的文件沙箱路径
- let context = ...; // 获取UIAbilityContext信息
- let pathDir = context.filesDir;
- let filePath = pathDir + '/test.txt';
-
- // 设置文件的数据等级为s0
- securityLabel.setSecurityLabel(filePath, 's0').then(() => {
- console.info('Succeeded in setSecurityLabeling.');
- }).catch((err) => {
- console.error(`Failed to setSecurityLabel. Code: ${err.code}, message: ${err.message}`);
- });
分布式文件系统为应用提供了跨设备文件访问的能力,开发者在多个设备安装同一应用时,通过基础文件接口,可跨设备读写其他设备该应用分布式文件路径(/data/storage/el2/distributedfiles/)下的文件。例如:多设备数据流转的场景,设备组网互联之后,设备A上的应用可访问设备B同应用分布式路径下的文件,当期望应用文件被其他设备访问时,只需将文件移动到分布式文件路径即可。
设备A上在分布式路径下创建测试文件,并写入内容。示例中的context的获取方式请参见获取UIAbility的上下文信息。
- import fs from '@ohos.file.fs';
-
- let context = ...; // 获取设备A的UIAbilityContext信息
- let pathDir = context.distributedFilesDir;
- // 获取分布式目录的文件路径
- let filePath = pathDir + '/test.txt';
-
- try {
- // 在分布式目录下创建文件
- let file = fs.openSync(filePath, fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE);
- console.info('Succeeded in createing.');
- // 向文件中写入内容
- fs.writeSync(file.fd, 'content');
- // 关闭文件
- fs.closeSync(file.fd);
- } catch (err) {
- console.error(`Failed to openSync / writeSync / closeSync. Code: ${err.code}, message: ${err.message}`);
- }

设备B上在分布式路径下读取测试文件。
- import fs from '@ohos.file.fs';
-
- let context = ...; // 获取设备B的UIAbilityContext信息
- let pathDir = context.distributedFilesDir;
- // 获取分布式目录的文件路径
- let filePath = pathDir + '/test.txt';
-
- try {
- // 打开分布式目录下的文件
- let file = fs.openSync(filePath, fs.OpenMode.READ_WRITE);
- // 定义接收读取数据的缓存
- let buffer = new ArrayBuffer(4096);
- // 读取文件的内容,返回值是读取到的字节个数
- let num = fs.readSync(file.fd, buffer, {
- offset: 0
- });
- // 打印读取到的文件数据
- console.info('read result: ' + String.fromCharCode.apply(null, new Uint8Array(buffer.slice(0, num))));
- } catch (err) {
- console.error(`Failed to openSync / readSync. Code: ${err.code}, message: ${err.message}`);
- }

Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。