【走进鸿蒙002】文件操作案例:创建、写入和读取文件

以下案例基于华为鸿蒙官方文档,展示如何通过ohos.file.fs模块实现文件的基本操作。代码使用TypeScript(ArkUI开发框架),适用于HarmonyOS应用开发。

一、创建并写入文件

typescript 复制代码
import fs from '@ohos.file.fs';
import common from '@ohos.app.ability.common';

// 获取应用沙箱路径
let context = getContext(this) as common.UIAbilityContext;
let sandboxPath = context.filesDir;

// 文件路径
let filePath = sandboxPath + '/test.txt';

try {
  // 创建文件并写入内容
  let file = fs.openSync(filePath, fs.OpenMode.CREATE | fs.OpenMode.READ_WRITE);
  fs.writeSync(file.fd, "Hello HarmonyOS");
  fs.closeSync(file.fd);
  console.log('文件写入成功');
} catch (err) {
  console.error(`操作失败: ${err.code}, ${err.message}`);
}

代码解读:

  • fs.openSync()使用CREATEREAD_WRITE标志创建可读写文件
  • fs.writeSync()同步写入字符串内容
  • 必须调用fs.closeSync()释放文件描述符

二、读取文件内容

typescript 复制代码
import fs from '@ohos.file.fs';

try {
  let file = fs.openSync(filePath, fs.OpenMode.READ_ONLY);
  let stat = fs.statSync(filePath);

  let buffer = new ArrayBuffer(stat.size);
  fs.readSync(file.fd, buffer);
  let textDecoder = new util.TextDecoder();
  let content = textDecoder.decode(buffer);
  console.log('文件内容: ' + content);

  fs.closeSync(file.fd);
} catch (err) {
  console.error(`读取失败: ${err.code}, ${err.message}`);
}

代码解读:

  • fs.statSync()获取文件大小信息
  • ArrayBuffer准备接收数据的缓冲区
  • TextDecoder将二进制数据转为字符串
运行效果展示
plaintext 复制代码
[控制台输出]
文件写入成功
文件内容: Hello HarmonyOS

三、 复制文件

typescript 复制代码
let destPath = sandboxPath + '/test_backup.txt';

try {
  fs.copyFileSync(filePath, destPath);
  console.log('文件复制成功');
} catch (err) {
  console.error(`复制失败: ${err.code}, ${err.message}`);
}

四、删除文件

typescript 复制代码
try {
  fs.unlinkSync(destPath);
  console.log('文件删除成功');
} catch (err) {
  console.error(`删除失败: ${err.code}, ${err.message}`);
}

关键API说明:

  • copyFileSync(): 同步复制文件
  • unlinkSync(): 同步删除文件
  • 所有同步方法均有对应的异步版本(如copyFile()

文件管理注意事项

  1. 权限声明:需在module.json5中添加文件访问权限
json 复制代码
"requestPermissions": [
  {
    "name": "ohos.permission.FILE_ACCESS_MANAGER"
  }
]
  1. 沙箱限制:应用默认只能访问自身沙箱目录
  2. 大文件处理:建议使用流式读写(createStream()/read())避免内存溢出

完整示例项目结构

复制代码
entry/src/main/
  ├── ets/
  │   ├── pages/
  │   │   └── Index.ets  # 主页面
  ├── resources/         # 静态资源
  └── module.json5       # 权限配置
相关推荐
后端小张3 小时前
【鸿蒙开发手册】重生之我要学习鸿蒙HarmonyOS开发
开发语言·学习·华为·架构·harmonyos·鸿蒙·鸿蒙系统
SWUT胖虎4 小时前
ArkTS 中@Extend 和@Styles 装饰器的用法和区别
harmonyos·arkts·鸿蒙·鸿蒙系统
鸿蒙小白龙1 天前
基于 OpenHarmony 6.0 的智能充电桩技术方案与实现
能源·harmonyos·鸿蒙·鸿蒙系统·open harmony
鸿蒙小白龙1 天前
Openharmony应用开发之Ability异常退出与UIAbility数据备份开发实战
harmonyos·鸿蒙·鸿蒙系统·open harmony
Damon小智1 天前
RedPlayer 视频播放器在 HarmonyOS 应用中的实践
音视频·harmonyos·鸿蒙·小红书·三方库·redplayer
鸿蒙小白龙2 天前
OpenHarmony 与 HarmonyOS 的 NAPI 开发实战对比:自上而下与自下而上的差异解析
harmonyos·鸿蒙·鸿蒙系统·open harmony
鸿蒙小白龙2 天前
OpenHarmony平台大语言模型本地推理:llama深度适配与部署技术详解
人工智能·语言模型·harmonyos·鸿蒙·鸿蒙系统·llama·open harmony
Bert丶seven3 天前
鸿蒙Harmony实战开发教学(No.4)-RichText组件基础到高阶介绍篇
华为·harmonyos·arkts·鸿蒙·鸿蒙系统·arkui·开发教程
鸿蒙小白龙3 天前
openharmony之分布式蓝牙实现多功能场景设备协同实战
分布式·harmonyos·鸿蒙·鸿蒙系统·open harmony
鸿蒙小白龙3 天前
openharmony之分布式购物车开发实战
分布式·harmonyos·鸿蒙·鸿蒙系统·open harmony