0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

[OpenHarmony北向應用開發(fā)]將應用資源目錄rawfile中的文件推送到應用沙箱

OpenHarmony開發(fā)經(jīng)驗 ? 來源:OpenHarmony開發(fā)經(jīng)驗 ? 作者:OpenHarmony開發(fā)經(jīng)驗 ? 2023-05-15 10:22 ? 次閱讀
  • 在應用開發(fā)調(diào)試時,可能需要向應用沙箱下推送一些文件用于應用訪問或者調(diào)試,本文介紹了如何放置在應用資源目錄rawfile中的文件推送到應用沙箱。并且在提供一個樣例Demo用于讀者老爺參考學習。
  • 樣例demo下載鏈接:https://gitee.com/from-north-to-north/OpenHarmony_hap/tree/master/rawfile_to_sandbox
  • 筆者開發(fā)環(huán)境:(本文提供的樣例demo 一定得是以下IDE和SDK版本或者更高版本才能編譯運行)
    • 開發(fā)板:潤和軟件DAYU200開發(fā)板
    • OpenHarmony版本:OpenHarmony3.2 release
    • IDE:DevEco Studio 3.1.0.400
    • SDK:API9(3.2.11.9)

  • 通過本文您將了解:

    1、應用資源resources目錄和應用沙箱的概念

    2、將應用資源目錄rawfile中的文件推送到應用沙箱

@toc


文章開始首先要熟悉兩個概念,OpenHarmony應用開發(fā)中 應用資源目錄中的rawfile目錄應用沙箱是什么?

1. 應用資源目錄中的rawfile目錄 是什么

  • OpenHarmony中應用開發(fā)使用的各類資源文件會被放進應用資源目錄中,它在應用源碼中長下面這個樣子。

    76e43fd045be8fc455d914358194300f827245 1.png

  • 應用資源resources目錄包括三大類目錄,一類為base目錄,一類為限定詞目錄,還有一類就是rawfile目錄。

  • 應用資源目錄中的rawfile目錄特點

    • 組織形式:支持創(chuàng)建多層子目錄,目錄名稱可以自定義,文件夾內(nèi)可以自由放置各類資源文件。rawfile目錄的文件不會根據(jù)設備狀態(tài)去匹配不同的資源。
    • 編譯方式:目錄中的資源文件會被直接打包進應用,不經(jīng)過編譯,也不會被賦予資源文件ID。
    • 引用方式:通過指定文件路徑和文件名來引用。
  • 參考鏈接:

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

2. 應用沙箱 是什么

  • 應用沙箱是一種以安全防護為目的的隔離機制,避免數(shù)據(jù)受到惡意路徑穿越訪問。在這種沙箱的保護機制下,應用可見的目錄范圍即為“應用沙箱目錄”。
  • OpenHarmony提供應用沙箱機制,增加目錄可見性數(shù)據(jù)訪問防線,減少了應用數(shù)據(jù)和用戶隱私信息泄露,建立了更加嚴格安全的應用沙盒隔離能力。
  • 詳細可參考:https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/file-management/app-sandbox-directory.md
  • 應用沙箱實現(xiàn)源碼:
    • 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
  • 開發(fā)者在應用開發(fā)調(diào)試時,可能需要向應用沙箱下推送一些文件以期望在應用內(nèi)訪問或測試,此時有兩種方式:
    • 第一種:可以通過DevEco Studio向應用安裝路徑中放入目標文件,詳見應用安裝資源訪問。
    • 第二種:在具備設備環(huán)境時,可以使用另一種更為靈活的方式,通過hdc工具來向設備中應用沙箱路徑推送文件。即本文介紹的內(nèi)容。
  • 本文介紹的就是第一種方式——通過DevEco Studio向應用安裝路徑中放入目標文件,也就是在應用資源目錄rawfile目錄中放入文件,然后將其推送至沙箱路徑。

3.1 樣例demo實現(xiàn)步驟:

  • 新建應用,創(chuàng)建資源文件,在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內(nèi)容為" + str);

    } catch (error) {
      console.info("[rawfile_copy_to_sandbox] ———————————————————————————————————————————————————————");
      console.info("[rawfile_copy_to_sandbox] rawfile中的input.txt內(nèi)容讀取失敗" + error);
    }
  }

  //用來拷貝rawfile文件中的input.txt到應用沙箱目錄下
  private async copy_rawfile__to_sandbox() {
    try {

      let file = this.dir+"input.txt";
      let sss = fs.createStreamSync(file, "w");//沒有會創(chuàng)建一個空的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到沙箱目錄下
            //調(diào)用的是私有的自定義的copy_rawfile__to_sandbox方法
            this.copy_rawfile__to_sandbox();
            this.readfile_from_rawfile();

          })

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

3.2 樣例實現(xiàn)效果

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

    image.png

  • 進入設備shell終端

    image.png

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 調(diào)試
    +關注

    關注

    7

    文章

    578

    瀏覽量

    33936
  • 應用開發(fā)

    關注

    0

    文章

    58

    瀏覽量

    9361
  • OpenHarmony
    +關注

    關注

    25

    文章

    3722

    瀏覽量

    16313
收藏 人收藏

    評論

    相關推薦

    OpenHarmony資源管理詳解 OpenHarmony資源分類和資源的訪問方式

    ,OpenHarmony 把這些應用的資源文件統(tǒng)一放在 resources 目錄下的各子目錄便于開發(fā)
    的頭像 發(fā)表于 07-05 06:24 ?3599次閱讀
    <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向應開發(fā)] 做一個 loading加載動畫

    /from-north-to-north/open-armony-north/tree/master/loading_animation - 作為一個OpenHarmony南向開發(fā)者,接觸
    的頭像 發(fā)表于 04-20 11:29 ?1904次閱讀
    [<b class='flag-5'>OpenHarmony</b><b class='flag-5'>北</b><b class='flag-5'>向應</b>用<b class='flag-5'>開發(fā)</b>] 做一個 loading加載動畫

    鴻蒙開發(fā)實戰(zhàn)-OpenHarmony沙箱文件

    openharmony文件管理模塊,按文件所有者分類分為應用文件和用戶文件和系統(tǒng)
    發(fā)表于 01-18 17:55

    鴻蒙OpenHarmony南向/向快速開發(fā)教程-迅為RK3568開發(fā)

    4.1學習之旅了嗎?快來加入我們,一起探索鴻蒙4.1系統(tǒng)的無限魅力吧! 【北京迅為】OpenHarmony學習開發(fā)系列教程(第1期 向基礎篇一) P0_先導課 P1_OpenHarmony
    發(fā)表于 07-23 10:44

    HarmonyOS應用開發(fā)-資源文件

    應用的資源文件(字符串、圖片、音頻等)統(tǒng)一存放于resources目錄下,便于開發(fā)者使用和維護。resources目錄包括兩大類目錄,一類為
    發(fā)表于 09-18 14:31

    HarmonyOS開發(fā)-eTS資源訪問

    目錄是默認存在的目錄。當應用的resources資源目錄沒有與設備狀態(tài)匹配的限定詞目錄時,會自動引用該
    發(fā)表于 12-20 17:50

    HarmonyOS應用開發(fā)資料(eTS文件/資源

    。當應用的resources資源目錄沒有與設備狀態(tài)匹配的限定詞目錄時,會自動引用該目錄資源文件
    發(fā)表于 03-17 15:04

    開發(fā)樣例】用JS寫一個OpenHarmony拼圖小游戲

    ││ jigsaw.css││ jigsaw.hml││ jigsaw.js│└─resources // 靜態(tài)資源目錄│├─base││├─element││└─media // 存放媒體資源│└─rawfile
    發(fā)表于 07-29 14:25

    開鴻智谷Niobe向應用實驗箱成為首個通過OpenHarmony兼容性測評的全場景實驗箱

    解決的現(xiàn)狀。開鴻智谷打造的Niobe向應用實驗箱,可使用真實的硬件進行沉浸式開發(fā),具有真機體驗設備虛擬化、分布式流轉、多設備協(xié)同等OpenHarmony核心技術特點,同時內(nèi)置豐富課程
    發(fā)表于 11-23 17:03

    HarmonyOS/OpenHarmony應用開發(fā)-HUAWEI DevEco Studio 3.1API9集成SDK

    ?Compatible SDK Version 9及以上一、添加應用配置文件1.“agconnect-services.json”文件下載到DevEco Studio項目的應用級資源目錄
    發(fā)表于 03-27 10:06

    imx8qxp-mek文件推送到“/vendor/etc”目錄時出現(xiàn)只讀文件系統(tǒng)錯誤是怎么回事?

    “/vendor/lib64/hw”和“/vendor/etc”目錄。由于默認文件系統(tǒng)是只讀的,因此我通過以下鏈接重新安裝文件系統(tǒng)。我可以推送 gps.default.so
    發(fā)表于 04-11 08:17

    文件管理開發(fā)指南全新登場,快來了解如何訪問各類文件

    /file-management-overview-0000001505679633-V3 二、應用沙箱,到底應該怎么用 應用沙箱推出以來,開發(fā)者一直在問,“應用沙箱到底應該怎么訪問”
    發(fā)表于 06-09 10:54

    HarmonyOS應用開發(fā)資源分類與訪問

    的限定詞目錄,或者在限定詞目錄找不到該資源時,才會去base目錄查找。
    發(fā)表于 09-12 18:17

    Native Rawfile開發(fā)指導

    場景介紹 開發(fā)者可以通過本指導了解在 HarmonyOS 應用,如何使用 Native Rawfile 接口操作 Rawfile 目錄
    發(fā)表于 12-11 16:28

    開鴻智谷Niobe向應用實驗箱通過OpenHarmony兼容性測評

    OpenHarmony向應用實驗箱(以下簡稱“Niobe向應用實驗箱”)通過了OpenAtom O
    的頭像 發(fā)表于 11-30 21:10 ?1048次閱讀