0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

[OpenHarmony北向应用开发]将应用资源目录rawfile中的文件推送到应用沙箱

OpenHarmony开发经验 来源:OpenHarmony开发经验 作者:OpenHarmony开发经验 2023-05-15 10:22 次阅读
  • 在应用开发调试时,可能需要向应用沙箱下推送一些文件用于应用访问或者调试,本文介绍了如何放置在应用资源目录rawfile中的文件推送到应用沙箱。并且在提供一个样例Demo用于读者老爷参考学习。
  • 样例demo下载链接:https://gitee.com/from-north-to-north/OpenHarmony_hap/tree/master/rawfile_to_sandbox
  • 笔者开发环境:(本文提供的样例demo 一定得是以下IDE和SDK版本或者更高版本才能编译运行)
    • 开发板:润和软件DAYU200开发板
    • OpenHarmony版本:OpenHarmony3.2 release
    • IDE:DevEco Studio 3.1.0.400
    • SDK:API9(3.2.11.9)

  • 通过本文您将了解:

    1、应用资源resources目录和应用沙箱的概念

    2、将应用资源目录rawfile中的文件推送到应用沙箱

@toc


文章开始首先要熟悉两个概念,OpenHarmony应用开发中 应用资源目录中的rawfile目录应用沙箱是什么?

1. 应用资源目录中的rawfile目录 是什么

  • OpenHarmony中应用开发使用的各类资源文件会被放进应用资源目录中,它在应用源码中长下面这个样子。

    76e43fd045be8fc455d914358194300f827245 1.png

  • 应用资源resources目录包括三大类目录,一类为base目录,一类为限定词目录,还有一类就是rawfile目录。

  • 应用资源目录中的rawfile目录特点

    • 组织形式:支持创建多层子目录,目录名称可以自定义,文件夹内可以自由放置各类资源文件。rawfile目录的文件不会根据设备状态去匹配不同的资源。
    • 编译方式:目录中的资源文件会被直接打包进应用,不经过编译,也不会被赋予资源文件ID。
    • 引用方式:通过指定文件路径和文件名来引用。
  • 参考链接:

    https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/quick-start/resource-categories-and-access.md

2. 应用沙箱 是什么

  • 应用沙箱是一种以安全防护为目的的隔离机制,避免数据受到恶意路径穿越访问。在这种沙箱的保护机制下,应用可见的目录范围即为“应用沙箱目录”。
  • OpenHarmony提供应用沙箱机制,增加目录可见性数据访问防线,减少了应用数据和用户隐私信息泄露,建立了更加严格安全的应用沙盒隔离能力。
  • 详细可参考:https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/file-management/app-sandbox-directory.md
  • 应用沙箱实现源码:
    • https://gitee.com/openharmony/startup_appspawn/blob/master/util/src/sandbox_utils.cpp
    • https://gitee.com/openharmony/startup_appspawn

3.向应用沙箱推送文件

  • 参考资料:https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/file-management/send-file-to-app-sandbox.md
  • 开发者在应用开发调试时,可能需要向应用沙箱下推送一些文件以期望在应用内访问或测试,此时有两种方式:
    • 第一种:可以通过DevEco Studio向应用安装路径中放入目标文件,详见应用安装资源访问。
    • 第二种:在具备设备环境时,可以使用另一种更为灵活的方式,通过hdc工具来向设备中应用沙箱路径推送文件。即本文介绍的内容。
  • 本文介绍的就是第一种方式——通过DevEco Studio向应用安装路径中放入目标文件,也就是在应用资源目录rawfile目录中放入文件,然后将其推送至沙箱路径。

3.1 样例demo实现步骤:

  • 新建应用,创建资源文件,在rawfile下面新建文件。笔者在样例中新建的的是input.txt
  • 获取context上下文,src/main/ets/entryability/EntryAbility.ts
onWindowStageCreate(windowStage: window.WindowStage) {
    // Main window is created, set main page for this ability
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate');
    
    globalThis.abilityContext = this.context
    //用全局对象获取context类的接口
    globalThis.context = this.context
    ...
}
  • 将应用资源目录rawfile中的文件推送到应用沙箱,实际上是通过沙箱与公共路径间文件的复制来完成的,使用到的API有getRawFd ,还使用到了一些文件管理相关的api
import fs from '@ohos.file.fs';

@Entry
@Component
struct Index {
  @State message: string = 'rawfile_copy_to_sandbox'

  //沙箱路径
  dir:string = globalThis.abilityContext.filesDir + "/";

  //从rawfile中读取input.txt文件,在log中显示
  private async readfile_from_rawfile() {
    try {
      let uint8Array = await globalThis.context.resourceManager.getRawFileContent('rawfile/input.txt');
      let str = String.fromCharCode.apply(null, new Uint8Array(uint8Array.buffer));
      console.info("[rawfile_copy_to_sandbox] ———————————————————————————————————————————————————————");
      console.info("[rawfile_copy_to_sandbox] rawfile中的input.txt内容为" + str);

    } catch (error) {
      console.info("[rawfile_copy_to_sandbox] ———————————————————————————————————————————————————————");
      console.info("[rawfile_copy_to_sandbox] rawfile中的input.txt内容读取失败" + error);
    }
  }

  //用来拷贝rawfile文件中的input.txt到应用沙箱目录下
  private async copy_rawfile__to_sandbox() {
    try {

      let file = this.dir+"input.txt";
      let sss = fs.createStreamSync(file, "w");//没有会创建一个空的input.txt
      sss.closeSync();

      //获取rawfile下input.txt
      globalThis.context.resourceManager.getRawFileDescriptor('rawfile/input.txt',(error, value) => {

        if (error != null) {  //getRawFileDescriptor运行失败
          console.info("[rawfile_copy_to_sandbox] ———————————————————————————————————————————————————————");
          console.log("[rawfile_copy_to_sandbox] getRawFileDescriptor api 运行失败: ${error.code}, message: ${error.message}.");
          console.log("[rawfile_copy_to_sandbox] 未能成功将rawfile下的input.txt文件拷贝到应用沙箱下 ");
        } else {             //getRawFileDescriptor运行成功
          let fd = value.fd;
          fs.copyFileSync(fd, file);
          console.info("[rawfile_copy_to_sandbox] ———————————————————————————————————————————————————————");
          console.log("[rawfile_copy_to_sandbox] getRawFileDescriptor api 运行成功");
          console.log("[rawfile_copy_to_sandbox] 成功将rawfile下的input.txt文件拷贝到应用沙箱下");
        }

      });

    } catch (error) {
      console.info("[rawfile_copy_to_sandbox] ———————————————————————————————————————————————————————");
      console.info("[rawfile_copy_to_sandbox] getRawFileDescriptor api 运行失败" + error);
      console.log("[rawfile_copy_to_sandbox] 未能成功将rawfile下的input.txt文件拷贝到应用沙箱下");
    }
  }

  build() {
    Row() {
      Column() {

        Button(this.message)
          .fontSize(25)
          .margin({top:0})
          .fontWeight(FontWeight.Normal)
          .backgroundColor(Color.Green) //设置按钮颜色
          .onClick(() => {

            console.info("[rawfile_copy_to_sandbox] 沙箱路径是"+ this.dir);

            //用来复制rawfile文件中的input.txt到沙箱目录下
            //调用的是私有的自定义的copy_rawfile__to_sandbox方法
            this.copy_rawfile__to_sandbox();
            this.readfile_from_rawfile();

          })

      }
      .width('100%')
    }
    .height('100%')
  }
}

3.2 样例实现效果

  • 日志显示:日志显示rawfile目录下的input.txt成功推送到/data/app/el2/100/base/com.sandbox.rawfile_to_sandbox/haps/entry/files/沙箱路径下

    image.png

  • 进入设备shell终端

    image.png

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 调试
    +关注

    关注

    7

    文章

    527

    浏览量

    33625
  • 应用开发
    +关注

    关注

    0

    文章

    52

    浏览量

    9141
  • OpenHarmony
    +关注

    关注

    23

    文章

    3322

    浏览量

    15161
收藏 人收藏

    评论

    相关推荐

    OpenHarmony资源管理详解 OpenHarmony资源分类和资源的访问方式

    OpenHarmony 把这些应用的资源文件统一放在 resources 目录下的各子目录中便于开发者使用和维护, resoures
    的头像 发表于 07-05 06:24 2973次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>资源</b>管理详解 <b class='flag-5'>OpenHarmony</b><b class='flag-5'>资源</b>分类和<b class='flag-5'>资源</b>的访问方式

    鸿蒙开发实战-OpenHarmony沙箱文件

    openharmony文件管理模块,按文件所有者分类分为应用文件和用户文件和系统
    发表于 01-18 17:55

    HarmonyOS应用开发-资源文件

    应用的资源文件(字符串、图片、音频等)统一存放于resources目录下,便于开发者使用和维护。resources目录包括两大类目录,一类为
    发表于 09-18 14:31

    向应用DirecttionalLayout布局的运用

    `蛟龙腾飞向应用研学,部分公开日志展示讨论,有不足和错误的地方欢迎大家指正。`
    发表于 11-21 17:52

    向应用:Java UI-TableLayout布局

    蛟龙腾飞向应用研学部分公开日志,不足之处欢迎指正。
    发表于 11-26 20:42

    HarmonyOS开发-eTS资源访问

    目录是默认存在的目录。当应用的resources资源目录没有与设备状态匹配的限定词目录时,会自动引用该
    发表于 12-20 17:50

    HarmonyOS应用开发资料(eTS文件/资源

    。当应用的resources资源目录没有与设备状态匹配的限定词目录时,会自动引用该目录资源文件
    发表于 03-17 15:04

    开发样例】用JS写一个OpenHarmony拼图小游戏

    ││ jigsaw.css││ jigsaw.hml││ jigsaw.js│└─resources // 静态资源目录│├─base││├─element││└─media // 存放媒体资源│└─rawfile
    发表于 07-29 14:25

    开鸿智谷Niobe向应用实验箱成为首个通过OpenHarmony兼容性测评的全场景实验箱

    解决的现状。开鸿智谷打造的Niobe向应用实验箱,可使用真实的硬件进行沉浸式开发,具有真机体验设备虚拟化、分布式流转、多设备协同等OpenHarmony核心技术特点,同时内置丰富课程
    发表于 11-23 17:03

    HarmonyOS/OpenHarmony应用开发-HUAWEI DevEco Studio 3.1API9集成SDK

    Compatible SDK Version 9及以上一、添加应用配置文件1.“agconnect-services.json”文件下载到DevEco Studio项目的应用级资源目录
    发表于 03-27 10:06

    imx8qxp-mek文件推送到“/vendor/etc”目录时出现只读文件系统错误是怎么回事?

    “/vendor/lib64/hw”和“/vendor/etc”目录。由于默认文件系统是只读的,因此我通过以下链接重新安装文件系统。我可以推送 gps.default.so
    发表于 04-11 08:17

    文件管理开发指南全新登场,快来了解如何访问各类文件

    /file-management-overview-0000001505679633-V3 二、应用沙箱,到底应该怎么用 应用沙箱推出以来,开发者一直在问,“应用沙箱到底应该怎么访问”
    发表于 06-09 10:54

    HarmonyOS应用开发资源分类与访问

    的限定词目录,或者在限定词目录找不到该资源时,才会去base目录查找。
    发表于 09-12 18:17

    Native Rawfile开发指导

    场景介绍 开发者可以通过本指导了解在 HarmonyOS 应用,如何使用 Native Rawfile 接口操作 Rawfile 目录
    发表于 12-11 16:28

    HarmonyOS项目和Android项目对比

    安卓 res 目录,这里用 resources 目录,它包括 base 和 rawfile 两部分,其中 base 是核心的资源目录,常用的都放在这里面,便于查找和使用。
    的头像 发表于 12-10 10:20 4207次阅读