openHarmony文件管理API实践 原创 精华

有点烟火
发布于 2022-3-28 09:36
浏览
4收藏

前言

    文件管理在我们日常使用手机中是一个非常重要的功能,我们可以通过文件管理相关 API 实现对指定文件的删除、复制、移动、压缩解压缩等操作。文件管理API 从Version 6 开始支持,由于目前华为对公共文件访问的API暂时还没开放,所以目前只能对应用私有目录下的文件操作权限

参考资料

HarmonyOS文件管理JS API

OpenHarmony API

获取当前应用私有目录

使用该功能模块对文件/目录进行操作前,需要先获取其绝对路径,获取方式及其接口用法请参考:Ability上下文

openHarmony文件管理API实践-鸿蒙开发者社区

在使用AbilityContext的功能前,需要通过getContext()先获取Context对象。

示例:

import ability_featureability from '@ohos.ability.featureAbility'
var context = ability_featureability.getContext();	

openHarmony文件管理API实践-鸿蒙开发者社区

获取应用内部存储目录除了可以通过AbilityContext之外,还可以使用特定scheme(只支持internal)来访问预定义的一些文件存取目录,详细描述见存储目录定义

不同设备上对应的实际位置不同。对于不在下列目录下的文件访问将被拒绝(禁止使用../等方式访问父目录)。

openHarmony文件管理API实践-鸿蒙开发者社区

通过实际代码操作发现context.getFilesDir()获取的目录/data/data/应用包名/files跟internal://app/的目录是一样的,这个在后面的示例代码中有体现

创建文件目录

官方API文档提供了多种创建文件目录的方式,这里只对其中一种方式进行演示,其他方式可自行验证

mkdir(path:string, mode?: number): Promise<void>

以异步方法创建目录,使用promise形式返回结果。这里我们通过context.getFilesDir()获取到当前的应用的私有目录,并在该文件夹下创建了4个文件夹openHarmony文件管理API实践-鸿蒙开发者社区

获取指定路径下的所有文件

获取指定目录下的所有文件需要用到system.file模块

import file from '@system.file';

虽然官方文档说从API Version 6开始,该接口不再维护,推荐使用新接口'@ohos.fileio'

但是我在fileio模块中并未找到相关接口,不知道是文档没有更新还是怎么回事,所以只能继续使用system.file模块了,期待华为后面更新文档

system.file模块接口文档参考获取指定路径下全部文件的列表

示例:

openHarmony文件管理API实践-鸿蒙开发者社区

在这里我们可以看到我通过获取internal://app/目录下的所有文件,可以看到我们上面在/data/data/应用包名/files下创建的文件夹

获取文件详细信息

以异步方法获取文件信息,使用callback形式返回结果。fileio.stat()

参数:

openHarmony文件管理API实践-鸿蒙开发者社区

示例:

fileio.stat(path, function (err, stat) {    
	});

删除目录

以异步方法删除目录,使用callback形式返回结果。fileio.rmdir (BETA)7+

参数:

openHarmony文件管理API实践-鸿蒙开发者社区

示例:

fileio.rmdir(path, function(err){ 
});

删除文件

以异步方法删除文件,使用callback形式返回结果。fileio.unlink()

参数:

openHarmony文件管理API实践-鸿蒙开发者社区

示例:

await fileio.unlink(path, function(err) {
    if (!err) {
        // do something
    }
});

文件的复制、移动操作

以异步方法复制文件,使用callback形式返回结果。fileio.copyFile()

参数:

openHarmony文件管理API实践-鸿蒙开发者社区

示例:

await fileio.copyFile(src, dest, function (err) { 
});

总结:以上只是部分接口实践,其他接接口大家可以参照华为官方API参考和openHarmony源码自行实践,这里推荐大家随时随地关注官方文档的更新,因为有些API虽然文档中介绍了,但是实际引用的时候发现相关功能并未实现。所以我们要时时刻刻的关注官方文档更新情况

©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
已于2022-3-30 10:10:55修改
5
收藏 4
回复
举报
3条回复
按时间正序
/
按时间倒序
红叶亦知秋
红叶亦知秋

整理和讲解非常全面,收藏了

回复
2022-3-28 11:11:14
有点烟火
有点烟火 回复了 红叶亦知秋
整理和讲解非常全面,收藏了

感谢支持

回复
2022-3-30 09:12:19
wx655737b876790
wx655737b876790

你好 发现 FileAccess 的 FileInfo 的属性 mimeType 为空,请问知道这是什么原因吗

回复
2023-11-17 17:54:45
回复
    相关推荐