首页 > 其他分享 >从零开始开发纯血鸿蒙应用之处理外部文件

从零开始开发纯血鸿蒙应用之处理外部文件

时间:2025-01-11 18:04:41浏览次数:3  
标签:picker 文件 鸿蒙 外部 app uri 纯血 从零开始 沙箱

从零开始开发纯血鸿蒙应用

一、外部文件

对于移动端app来说,什么是外部文件呢?是那些存储在手机之外的存储介质中的文件吗?还是另有说法呢?

不同于桌面端的应用,手机操作系统对文件的访问控制非常严格,但app读写文件又是非常基础的需要,所以,像华为的鸿蒙系统以及苹果手机的iOS系统,都专门为app开辟了一个名为沙箱目录的目录区域,每个app都有自己专属的一个沙箱目录。

app在自己的沙箱目录里,可以很自由的进行文件的创建和读写、以及删除。对于存放在自己的沙箱目录中的文件,我称之为app的内部文件,而那些存储在自己的沙箱目录外的文件,或是存储在用户目录的文件,也或是存储在其他app的沙箱目录中的文件,我就称之为外部文件

需要提醒的是,app的沙箱目录,在手机上用文件管理是看不到的,必须借助电脑上的专门工具,例如 DevEco Studio 才能看到。app 的沙箱目录一般路径为 /data/app/el2/100/base/[package name]/hap/entry
在这里插入图片描述
对于 DevEco Studio 提供的 Device File Browser,我想多说两句,一是该工具提供了两种查看视图,普通文件视图和沙箱文件视图,第二种视图依赖于应用需要在 module.josn5 中开启 ohos.permission.INTERNET 权限;二是该工具并不是所有app的沙箱目录都可以查看:
在这里插入图片描述

二、外部文件的访问形式

外部文件的访问,主要有两种形式:主动访问被动访问

1、主动访问

所谓主动访问,就是app自己通过主动调用鸿蒙 API——picker,拉起文件选择面板,让用户去选择文件,然后再对目标文件进行内容读取和处理。
在这里插入图片描述
picker 会将选中的目标文件的File URI暴露出来,通过该File URI,就可以按图索骥进行文件操作,比如读取文件属性信息。

2、被动访问

在这里插入图片描述
如上图的这种操作,我相信大家平日的手机使用过程中,都会遇到。当一个文件不是当前app能够进行处理的时候,往往系统就会让你选中用其他应用去处理,实际上,这种方式就是让你选择的那个目标应用被动地进行外部文件的访问和处理。

在鸿蒙系统中,一个app默认是不具有被动处理外部文件的能力的,想要具备这种能力,需要app自己向系统声明,一般就是在 module.json5 文件中进行相关配置。

三、代码实现

1、DocumentViewPicker

鸿蒙系统针对不同的文件类型,提供了多种具体的 picker,其中,针对文件的就是这里即将进行介绍的DocumentViewPicker

DocumentViewPicker 的使用非常简单,只需传入一个 option 即可:

const option: picker.DocumentSelectOptions = new picker.DocumentSelectOptions();
option.maxSelectNumber = 1;
option.fileSuffixFilters = ['.txt', '.log', '.csv', '.ini', '.conf', '.md', '.markdown', '.rtf', '.json',
  '.xml', '.ets', '.java', '.py',
  '.c', '.cpp', '.h', '.html']
const filePicker = new picker.DocumentViewPicker(this.ctx);
filePicker.select(option).then((uri) => {
  Logger.info(`选中的文件:${uri}`, TAG);
  const param: StrRouterParam = new StrRouterParam(uri[0]);
  router.pushUrl({
    url: "pages/ImportFilePage",
    params: param
  })
})

过程步骤可以描述为如下的几步:
1)创建一个 picker.DocumentSelectOptions 对象
2)使用 picker.DocumentSelectOptions 对象的属性,设置最大选中数、目标文件后缀等必要的文件过滤条件。picker.DocumentSelectOptions 对象一共有如下属性:

  • maxSelectNumber:最大可选中数,值域范围1~500,如果是选择目录,那么该值只能为1;默认值为 1.
  • defaultFilePathUri:指定选择文件或目录路径,即默认的文件或目录路径;没有默认值。
  • fileSuffixFilters:目标文件的后缀;默认全部文件。
  • selectMode:选择模式,用于设置支持选择的资源类型:文件、文件夹或二者混合;默认是文件。
  • authMode:授权模式,默认为 false;当值为 true,则 defaultFilePathUri 必填,表示待授权的 uri。
    3)利用 UI 上下文,创建一个 picker.DocumentViewPicker 对象,并使用该对象的 select 方法拉起文件选择面板,而select 方法的回调处理中,可以获得用户选中的文件的 uri,我这里是将该 uri 通过 router 路由携带跳转到专门用展示外部文件的页面里,然后展示文件内容:
    在这里插入图片描述

2、Ability Skills

前面说了,应用默认是不具有被动处理外部文件的能力的,除非向系统声明了,而这个声明就是在 module.json5 中进行能力声明:
在这里插入图片描述
skills 标签里的 actions 标签,用于声明具体的能力动作,上面的ohos.want.action.viewData,就表示查看数据的操作;同样位于 skills 标签里面的 uris 标签,可以为 viewData 动作进行进一步的细化,声明支持何种类型的数据的查看,如上的配置,则表示支持通用纯文本文件类型的数据的查看

通过类似如上的配置,当用户需要进入“使用其他应用打开文件”的场景时,系统就会判断待打开的文件,是否与应用在 module.json5 文件中声明的数据查看能力相符合,如果符合就会展示在应用候选中,否则就不展示。

3、onNewWant 函数

光在 module.json5 文件中声明 Ability Skills,尚不足以形成真正的处理外部文件的能力,因为传记录的文件uri 没有任何代码进行读取等文件操作,而想要实现这一步骤,就需要用到一个应用生命周期函数 onNewWant 函数
在这里插入图片描述
当应用已经完成冷启动并进入后台运行状态时,用户的“选择某某app打开文件”的操作,就会触发该生命周期函数,而函数的 Want 参数里面,就包含了用户想要打开的文件的 File Uri,因此,就可以用类似如下的代码进行处理:
在这里插入图片描述

4、冷启动时处理外部文件

用户在其他app页面,选择用当前应用去打开文件时,当前应用可能并未完成冷启动,这时候,就不会触发 OnNewWant 函数,而是触发 onCreate 函数:
在这里插入图片描述
然而,由于 onCreate 函数早于 onWindowStageCreate 的执行,意味着 UI 进程还没开始,也就是页面跳转动作还不能进行,所以,在 onCreate 函数里面处理其他app传进来的文件,是不合适的,不妨移步到 onWindowStageCreate 函数中。

在这里插入图片描述
onWindowStageCreate 函数的参数,虽然没有 Want 对象,但是 this 上下文里面就有有一个 launchWant 实例,借助它依旧能够获取到其他app传入的文件 uri,由于 windowStage.loadContent 不像 router.push 那样携带参数,而 windowStage.loadContent 在被执行完成之前,应用主页未被渲染出来,router.push 依旧用不了,所以,我利用 AppStorage 去完成外部文件 uri 的透传:
在这里插入图片描述
在应用主页的 aboutToAppear 生命周期函数中,判断 AppStorage 中记录的 SignalConstants.SIGNAL_OUTFILE_URI 是否为非空字符串,如果是,则将对应的外部文件的 File Uri 通过 router.push 携带跳转到 ViewOutsideFile 页面,从而完成冷启动状态下对外部文件的处理。

标签:picker,文件,鸿蒙,外部,app,uri,纯血,从零开始,沙箱
From: https://blog.csdn.net/qq_42896653/article/details/145069717

相关文章

  • 《盘古大模型——鸿蒙NEXT的智慧引擎》
    在当今科技飞速发展的时代,华为HarmonyOSNEXT的发布无疑是操作系统领域的一颗重磅炸弹,其将人工智能与操作系统深度融合,开启了智能新时代。而盘古大模型在其中发挥着至关重要的核心作用。赋予小艺智能助手超强能力在鸿蒙NEXT中,盘古大模型赋予了小艺智能助手更强的记忆、推......
  • 请说说鸿蒙和android有什么区别?
    鸿蒙与Android在前端开发方面的区别主要体现在以下几个方面:开发框架和语言:鸿蒙使用ArkTS语言,结合ArkUI声明式UI框架进行开发,提供了一套全新的组件和布局系统,更易于构建跨设备的应用。Android则主要使用Java或Kotlin语言,搭配AndroidSDK进行开发,UI布局使用XML,近年来也支持Jet......
  • 鸿蒙面试 2025-01-10
    写了鉴权工具,你在项目中申请了那些权限?(常用权限)位置权限 :ohos.permission.LOCATION_IN_BACKGROUND:允许应用在后台访问位置信息。ohos.permission.LOCATION:允许应用访问精确的位置信息。ohos.permission.APPROXIMATELY_LOCATION:允许应用访问大致的位置信息。相机权限 :......
  • 全面解读华为鸿蒙系统:从技术到生态的全新突破
    近年来,随着物联网(IoT)设备的快速普及,操作系统领域迎来了新的变革。华为推出的**鸿蒙系统(HarmonyOS)**正以强大的技术实力和生态布局,逐步成为物联网时代的关键操作系统。今天,我们就从技术架构、特点以及开发者生态三个方面,来全面解读鸿蒙系统。【点赞+关注】私我领取华为认证考......
  • python SQLAlchemy ORM——从零开始学习 04 如何过滤(筛选)数据库中的数据
    04如何过滤(筛选)数据库中的数据从数据库中获筛选数据主要应用以下几个接口:filter、filter_by、以及where。前两个在02已经展开说过,先展开说where接口前情提要:依赖03提及的model【本质上就是数据库的链接,有可忽视】当前的数据库表内容如下,仅作例子,不相同根据自身数据库操作即......
  • 使用 Taro 开发鸿蒙原生应用 —— 快速上手,鸿蒙应用开发指南
    作者:京东零售利齐诺随着鸿蒙系统的不断完善,许多应用厂商都希望将自己的应用移植到鸿蒙平台上。最近,Taro发布了v4.0.0-beta.x版本,支持使用Taro快速开发鸿蒙原生应用,也可将现有的小程序转换为鸿蒙原生应用。在《使用Taro开发鸿蒙原生应用》系列文章中,我们已经介绍了鸿......
  • python SQLAlchemy ORM——从零开始学习03 如何针对数据库信息进行排序
    03如何进行排序3-1准备工作:因为要排序,所以需要随机多谢数据,model见后文。也需要random进行随机frommodelimportUser,Enginefromsqlalchemy.ormimportsessionmakerimportrandomSession=sessionmaker(bind=Engine)session=Session()defadd_random():na......
  • [读书日志]从零开始学习Chisel 第十一篇:Scala的类型参数化(敏捷硬件开发语言Chisel与数
    8.Scala的类型参数化8.1var类型的字段对于可重新赋值的字段,可以执行两个基本操作,获取字段值或设置为一个新值。如果在类中定义了一个var类型的字段,那么编译器会把这个变量限制为private[this],同时隐式地定义一个名为变量名的getter方法和一个名为变量名_=的setter方法。......
  • [读书日志]从零开始学习Chisel 第六篇:Scala面向对象编程——特质(敏捷硬件开发语言Chis
    3.4特质3.4.1什么是特质特质使用trait开头,它与单例对象很像,两者都不能有输入参数,但单例对象是具体的,特质是抽象的。两者都不能用new实例化,类,单例对象,特质三者内部都可以包含字段和方法,以及其他类,单例对象,特质的定义。特质可以被其他类,单例对象和特质“混入”。混入在超类......
  • [读书日志]从零开始学习Chisel 第十篇:Scala的模式匹配(敏捷硬件开发语言Chisel与数字系
    7.Scala的模式匹配7.1样例类和对象定义类时,如果在最前面加上关键字case,则这个类就被称为样例类。Scala的编译器自动对样例类添加一些语法便利:添加一个与类同名的工厂方法,可以通过类名(参数)来构造对象,而不需要使用new类名(参数)来构造;参数列表的每个参数都隐式地获得......