Skip to content

保存读取沙盒文件

有些时候需要保存并读取沙盒环境的文件。这样做保存一些临时文件,确保发送网络之前数据不会丢失,或者存储一些只需要在本地使用的数据等等。本文介绍一下相关的操作方式。

获取文件路径

想要保存或者读取文件,首先需要获取文件路径。鸿蒙这边文件地址大体有三种,第一个是本地沙盒路径,第二个是系统存储文件,第三个是包内的资源文件,本文主要介绍的是沙盒文件。系统文件需要申请权限,包内的资源文件一般来说是只读的。

获取沙盒文件地址需要先获取上下文的相对路径地址:

javascript
import { common } from '@kit.AbilityKit';
let context = getContext(this) as common.UIAbilityContext;
let filesDir = context.filesDir;

此时获取到的 filesDir 就是沙盒文件的绝对路径。

保存文件

保存文件需要以写的形式打开一个文件,为了在文件不存在的时候创建文件,使用 create 标识。

javascript
import { fileIo as fs, ReadOptions } from '@kit.CoreFileKit';

saveFile(buf: ArrayBuffer, path: string) {
  try {
    let file = fs.openSync(`${filesDir}/${path}`, fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE);
    let num = fs.writeSync(file.fd, buf);
    fs.closeSync(file)
  } catch (error) {
  }
}

saveFile('sample.jpg')

需要把想要保存的文件转换成arraybuffer的格式,然后就能直接写入到文件当中了。这样就完成文件的保存了。

读取文件

读取文件可以创建一个大的arraybuffer,然后读取文件内容到这个arraybuffer中。然后根据返回的读取长度再裁剪arraybuffer获取完整的数据,但是arraybuffer的大小要是小了就需要多次读取才能完成文件的整体读取,对于小文件来说这么弄总是不太方便。

本例子主要针对于不是那么大的文件,想要一次性读取文件内容的情况。

首先使用 stat 获取文件信息,根据文件的大小创建一个arraybuffer,然后读取文件内容到这个arraybuffer中。这样就能一次读取了。

javascript
import { fileIo as fs, ReadOptions } from '@kit.CoreFileKit';

readFile(path: string): ArrayBuffer | null {
  try {
    let file = fs.openSync(`${filesDir}/${path}`, fs.OpenMode.READ_WRITE);
    let stat = fs.statSync(`${filesDir}/${path}`);
    hilog.info(gDomain, TAG, `file size ${stat.size}`)
    let buf = new ArrayBuffer(stat.size);
    let num = fs.readSync(file.fd, buf);
    fs.closeSync(file);
    return buf
  } catch (error) {
    return null
  }
}