鸿蒙next开发:分布式文件系统(跨设备文件访问)

往期鸿蒙全套实战文章必看:(附带鸿蒙全栈学习资料)


跨设备文件访问

分布式文件系统为应用提供了跨设备文件访问的能力,开发者在两个设备上安装同一应用时,通过基础文件接口,可跨设备读写另一个设备上该应用分布式目录(/data/storage/el2/distributedfiles/)下的文件。例如:多设备数据流转的场景,设备组网互联之后,设备A上的应用可访问设备B上的同应用分布式目录下的文件,当期望应用文件被其他设备访问时,只需将文件移动到分布式目录即可。

开发步骤

  1. 完成分布式组网。

    将需要跨设备访问的两个设备登录同一账号,保证设备蓝牙和Wi-Fi功能开启,蓝牙无需互连,Wi-Fi无需接入同一个局域网。

  2. 授权分布式数据同步权限。

    分布式数据同步权限的授权方式为user_grant,因此需要调用requestPermissionsFromUser接口,以动态弹窗的方式向用户申请授权。

import { common, abilityAccessCtrl } from '@kit.AbilityKit';
import { BusinessError } from '@kit.BasicServicesKit';
let context = getContext(this) as common.UIAbilityContext; // 获取UIAbilityContext信息
let atManager = abilityAccessCtrl.createAtManager();
try {
  //以动态弹窗的方式向用户申请授权
  atManager.requestPermissionsFromUser(context, ['ohos.permission.DISTRIBUTED_DATASYNC']).then((result) => {
    console.info(`request permission result: ${JSON.stringify(result)}`);
  }).catch((err: BusinessError) => {
    console.error(`Failed to request permissions from user. Code: ${err.code}, message: ${err.message}`);
  })
} catch (error) {
  let err: BusinessError = error as BusinessError;
  console.error(`Catch err. Failed to request permissions from user. Code: ${err.code}, message: ${err.message}`);
}
  1. 访问跨设备文件。

    同一应用不同设备之间实现跨设备文件访问,只需要将对应的文件放在应用沙箱的分布式目录即可。

    设备A上在分布式目录下创建测试文件,并写入内容。

    import { fileIo as fs } from '@kit.CoreFileKit';
    import { common } from '@kit.AbilityKit';
    import { BusinessError } from '@kit.BasicServicesKit';
    
    
    let context = getContext(this) as common.UIAbilityContext; // 获取设备A的UIAbilityContext信息
    let pathDir: string = context.distributedFilesDir;
    // 获取分布式目录的文件路径
    let filePath: string = pathDir + '/test.txt';
    
    
    try {
      // 在分布式目录下创建文件
      let file = fs.openSync(filePath, fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE);
      console.info('Succeeded in creating.');
      // 向文件中写入内容
      fs.writeSync(file.fd, 'content');
      // 关闭文件
      fs.closeSync(file.fd);
    } catch (error) {
      let err: BusinessError = error as BusinessError;
      console.error(`Failed to openSync / writeSync / closeSync. Code: ${err.code}, message: ${err.message}`);
    } 

    设备B主动向设备A发起建链,建链成功后设备B可在分布式目录下读取测试文件。

    说明

    这里通过分布式设备管理的接口获取设备networkId。

    import { fileIo as fs } from '@kit.CoreFileKit';
    import { common } from '@kit.AbilityKit';
    import { BusinessError } from '@kit.BasicServicesKit';
    import { buffer } from '@kit.ArkTS';
    import { distributedDeviceManager } from '@kit.DistributedServiceKit';
    
    
    // 通过分布式设备管理的接口获取设备A的networkId信息
    let dmInstance = distributedDeviceManager.createDeviceManager("com.example.hap");
    let deviceInfoList: Array<distributedDeviceManager.DeviceBasicInfo> = dmInstance.getAvailableDeviceListSync();
    if (deviceInfoList && deviceInfoList.length > 0) {
      console.info(`Success to get available device list`);
      let networkId = deviceInfoList[0].networkId;
      // 定义访问公共文件目录的回调
      let listeners : fs.DfsListeners = {
        onStatus: (networkId: string, status: number): void => {
          console.error(`Failed to access public directory,${status}`);
        }
      };
      // 开始跨设备文件访问
      fs.connectDfs(networkId, listeners).then(() => {
        console.info("Success to connect dfs");
        // 请在组件内获取context,确保this.getUIContext().getHostContext()返回结果为UIAbilityContext
        let context = getContext(); // 获取设备B的UIAbilityContext信息 
        let pathDir: string = context.distributedFilesDir;
        // 获取分布式目录的文件路径
        let filePath: string = pathDir + '/test.txt';
        try {
          // 打开分布式目录下的文件
          let file = fs.openSync(filePath, fs.OpenMode.READ_WRITE);
          // 定义接收读取数据的缓存
          let arrayBuffer = new ArrayBuffer(4096);
          // 读取文件的内容,返回值是读取到的字节个数
          class Option {
              public offset: number = 0;
              public length: number = 0;
          };
          let option = new Option();
          option.length = arrayBuffer.byteLength;
          let num = fs.readSync(file.fd, arrayBuffer, option);
          // 打印读取到的文件数据
          let buf = buffer.from(arrayBuffer, 0, num);
          console.info('read result: ' + buf.toString());
          fs.closeSync(file);
        } catch (error) {
          let err: BusinessError = error as BusinessError;
          console.error(`Failed to openSync / readSync. Code: ${err.code}, message: ${err.message}`);
        }
      }).catch((error: BusinessError) => {
        let err: BusinessError = error as BusinessError;
        console.error(`Failed to connect dfs. Code: ${err.code}, message: ${err.message}`);
      });
    }
  2. B设备访问跨设备文件完成,断开链路。

    import { BusinessError } from '@kit.BasicServicesKit';
    import { distributedDeviceManager } from '@kit.DistributedServiceKit';
    import { fileIo as fs } from '@kit.CoreFileKit';
    
    
    // 获取设备A的networkId
    let dmInstance = distributedDeviceManager.createDeviceManager("com.example.hap");
    let deviceInfoList: Array<distributedDeviceManager.DeviceBasicInfo> = dmInstance.getAvailableDeviceListSync();
    if (deviceInfoList && deviceInfoList.length > 0) {
      console.info(`Success to get available device list`);
      let networkId = deviceInfoList[0].networkId;
     // 关闭跨设备文件访问
      fs.disconnectDfs(networkId).then(() => {
        console.info("Success to disconnect dfs");
      }).catch((err: BusinessError) => {
        console.error(`Failed to disconnect dfs. Code: ${err.code}, message: ${err.message}`);
      })
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值