flutter:文件系统目录、文件读写

news2024/11/25 11:53:28

参考

参考:老孟 文件存储和网络请求

数据存储

Dart的 IO 库包含了文件读写的相关类,它属于 Dart 语法标准的一部分,所以通过 Dart IO 库,无论是 Dart VM 下的脚本还是 Flutter,都是通过 Dart IO 库来操作文件的。但是不同的平台对应的文件系统是不同的,比如文件路径,因此通常使用Google 官方维护的插件 path_provider。

安装

在项目的 pubspec.yaml 文件中添加依赖

dependencies:
  path_provider: ^2.0.11

安装

flutter pub get

常用方法

getTemporaryDirectory
临时目录,适用于下载的缓存文件,此目录随时可以清除,此目录为应用程序私有目录,其他应用程序无法访问此目录。

getApplicationSupportDirectory
获取应用程序的支持目录。这个函数返回一个Future<Directory>对象,表示应用程序的支持目录。

getLibraryDirectory
返回应用程序的库目录。这个目录通常用于存储应用程序的共享库或插件。

getApplicationDocumentsDirectory
应用程序的文档目录。文档目录是应用程序可以使用的持久性存储空间,通常用于存储用户生成的文件或其他数据。

getExternalStorageDirectory
应用程序可以访问顶级存储的目录的路径。由于此功能仅在Android上可用,因此应在发出此函数调用之前确定当前操作系统。

getExternalCacheDirectories
存储特定于应用程序的外部缓存数据的目录的路径。

getDownloadsDirectory
存储下载文件的目录的路径,这通常仅与台式机操作系统有关。 在Android和iOS上,此函数将引发[UnsupportedError]异常。

方法使用场景

下面从 Android 和 iOS 平台的角度介绍其文件路径,最后给出路径使用的建议以及使用过程中需要注意的事项。

安卓文件存储

Android 文件存储分为内部存储和外部存储。

内部存储:

  • 其他应用无法访问这些数据
  • 当应用卸载的时候,这些数据也会被删除,避免垃圾文件
  • 不需要申请额外权限
  • 存储的空间有限,此目录数据随时可能被系统清除,也可以通过 设置 中的 清除数据 可以清除此目录数据。

内部存储目录结构:

  • cache 目录:对应 getTemporaryDirectory 方法,用于缓存文件,此目录随时可能被系统清除。
  • files 目录:对应 getApplicationSupportDirectory 方法。
  • code_cache:此目录存储 Flutter 相关代码和资源
  • shared_prefs:SharePreferences(轻量级的本地存储) 的默认路径
  • app_flutter:对应 getApplicationDocumentsDirectory方法。
  • app_flutter/dbName:使用 sqlite(轻量级的关系型数据库,用于本地存储和管理应用程序的数据) 的默认路径,sqlite 也可以指定位置。

外部存储

  • 当应用卸载的时候,这些数据也会被删除,避免垃圾文件
  • 不需要申请额外权限
  • 空间大且不会被系统清除,通过 设置 中的 清除数据 可以清除此目录数据。
  • 用户可以直接对文件进行删除、导入操作。

外部存储目录结构

  • cache:缓存目录,对应 getExternalCacheDirectories 方法。
  • files:对应 getExternalStorageDirectories 方法。

苹果文件存储

iOS 文件存储相比 Android 要简单的多,因为 iOS 对用户隐私保护非常严格,每个 iOS 应用程序都有一个单独的文件系统,而且只能在对应的文件系统中进行操作,此区域被称为沙盒。

每个应用沙盒含有3个文件夹:Documents, Library 和 tmp:

  • Documents:应用程序数据文件写入到这个目录下。这个目录用于存储用户数据。保存应用程序的重要数据文件和用户数据文件等。对应 getApplicationDocumentsDirectory 方法。
  • Library:对应 getLibraryDirectory 方法
  • tmp:存放临时文件,不会被备份,而且这个文件下的数据有可能随时被清除的可能,按照官方说法每三天清理一次缓存数据。

总结

  • SharePreferences 和 sqlite 数据建议存放在内部存储,插件已经帮我们完成了,无需手动处理。
  • 严格保密的数据,比如用户数据,建议存放在内部存储,对应 getApplicationSupportDirectory 方法。
  • 其余所有的数据建议存放 Android/data/包名/ ,对应 getExternalCacheDirectories 和 getExternalStorageDirectories 方法。

基本使用

flutter官方示例

文件读写

文件夹

创建文件夹

ElevatedButton(onPressed: () async{
      // 获取应用程序目录
      Directory appDocumentDriectory = await getApplicationDocumentsDirectory();
      // 路径,Platform.pathSeparator 平台下的路径分隔符
      String path = '${appDocumentDriectory.path}${Platform.pathSeparator}myAppName';
      // 读取对应路径下的文件夹
      var dir = Directory(path);
      if(dir.existsSync()){
        print("当前文件夹已存在");
      }else{
        // 创建文件,可选参数recursive:true表示可以创建嵌套文件夹,false表示只能创建最后一级文件夹(上一级文件不存在会报错),默认false
        var result = await dir.create(recursive: true);
        print("文件创建成功:${result}");
      }
  }, child: const Text("创建文件夹"));

在这里插入图片描述

遍历文件夹

ElevatedButton(onPressed: () async{
  // 获取应用程序目录
  Directory appDocumentDirectory = await getApplicationDocumentsDirectory();
  String path = '${appDocumentDirectory.path}${Platform.pathSeparator}';
  // 文件列表,可选参数recursive,默认值为false,只遍历当前目录;设置为true时会遍历当前目录及子目录
  Stream<FileSystemEntity> fileList = Directory(path).list();
  await for(FileSystemEntity fileSystemEntity in fileList){
    print(fileSystemEntity);
  }
}, child: const Text("遍历文件"))

在这里插入图片描述
判断文件的类型

await for(FileSystemEntity fileSystemEntity in fileList){
  print('$fileSystemEntity');
  FileSystemEntityType type = FileSystemEntity.typeSync(fileSystemEntity.path);
}

文件的类型:

  • file:文件
  • directory:文件夹
  • link:链接文件,比如:HTML文件、PDF文件、图片文件、音频文件、文本文件、JSON文件
  • notFound:未知

文件夹重命名

_dirRename() async{
  Directory documentsDirectory = await getApplicationDocumentsDirectory();
  String path = '${documentsDirectory.path}${Platform.pathSeparator}dirName';
  var dir = Directory(path);
  var newName= await dir.rename('${dir.parent.absolute.path}${Platform.pathSeparator}newName');
}

删除文件夹

ElevatedButton(onPressed: () async{
          // 获取应用程序文件目录
          Directory appDocumentDirectory = await getApplicationDocumentsDirectory();
          String path ='${appDocumentDirectory.path}${Platform.pathSeparator}myAppName';
          try{
            // 可选参数recursive,默认false,只删除文件夹,如果文件夹下有内容则无法删除并抛出异常;true删除文件夹及文件夹下所有内容
             var dir = await Directory(path).delete();
             print('文件夹$path删除成功');
          }catch(err){
            print('文件夹$path删除失败:$err');
          }
        }, child: const Text("删除文件夹"))

在这里插入图片描述

文件

创建文件

ElevatedButton(onPressed: () async{
          // 获取应用程序目录
          Directory appDocumentDirectory = await getApplicationDocumentsDirectory();
          // 路径
          String path = '${appDocumentDirectory.path}${Platform.pathSeparator}myAppName${Platform.pathSeparator}test.txt';
          File file = File(path);
          if(file.existsSync()){
            print("文件已存在");
          }else{
            // 文件创建也存在recursive属性
            var file = await File(path).create();
            print("文件创建成功:$file");
          }

}, child: const Text("创建文件"))

在这里插入图片描述
写入数据

写入字符串,覆盖写入

ElevatedButton(onPressed: () async{
 // 获取应用程序目录
 Directory appDocumentDirectory = await getApplicationDocumentsDirectory();
 // 路径
 String path = '${appDocumentDirectory.path}${Platform.pathSeparator}myAppName${Platform.pathSeparator}test.txt';
 File file = File(path);
 if(file.existsSync()){
   var res = await file.writeAsString("写入数据");
   print("写入成功:$res");
 }else{
   print("文件不存在");
 }
}, child: const Text("写入数据")),

在这里插入图片描述
写入bytes 数据,覆盖写入

file.writeAsBytes(Utf8Encoder().convert("bytes 格式"));

追加写入

file.openWrite(mode: FileMode.append).write('追加写入');

读取数据
读取字符串

ElevatedButton(
  onPressed: () async {
    //  应用程序目录
    Directory appDocumentDirectory =
        await getApplicationDocumentsDirectory();
    // 路径
    String path =
        '${appDocumentDirectory.path}${Platform.pathSeparator}myAppName${Platform.pathSeparator}test.txt';
    File file = File(path);
    if (file.existsSync()) {
      var res = await file.readAsString(encoding: utf8);
      print("文件读取成功,内容是:$res");
    } else {
      print("文件不存在");
    }
  },
  child: const Text("文件读取"))

在这里插入图片描述
按行读取数据

List<String> lines = await file.readAsLines();
lines.forEach((element) {
  print('$element');
});

读取 bytes 并转换为String

Utf8Decoder().convert(await file.readAsBytes());

删除

file.delete();

读取 assets 文件

读取项目中文件,项目中使用的文件一般都放在lib/assets
在这里插入图片描述
如果需要访问,需要在pubspec.yaml 文件中添加配置,例如:

assets:
  - assets/json/

读取

_loadAsset(BuildContext context) async{
  var jsonStr = await DefaultAssetBundle.of(context)
      .loadString('assets/json/data.json');
  var list = json.decode(jsonStr);
  list.forEach((element) {
    print('$element');
  });
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/638972.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

H桥级联型五电平逆变器MATLAB仿真模型

H桥级联型五电平逆变器MATLAB仿真模型资源-CSDN文库https://download.csdn.net/download/weixin_56691527/87899094 模型简介&#xff1a; MATLAB21b版本 逆变器采用H桥级联的形式连接&#xff0c;加设LCL滤波器&#xff0c;三相负载构成主电路。 采用SPWM调制&#xff0c;可…

解密混沌工程——混沌工程价值

在数字化转型、十四五规划的大背景 下&#xff0c;大规模上云、分布式的核心改造等“云化”逐渐走进企业。 但是&#xff0c;云化的发展&#xff0c;使企业系统的复杂度呈指数级增长&#xff0c;故障越来越多。 企业在数字化转型中拥抱云计算、 信创国产化、分布式核心等新技…

【软件测试】性能测试的9大误区,带你少走弯路...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 误区1&#xff1a…

外卖点餐APP小程序系统开发功能有哪些?

外卖点餐APP小程序系统开发功能有哪些&#xff1f; 1、餐饮分类。点餐外卖小程序需要提供餐厅列表&#xff0c;以便于用户浏览餐厅信息。用户可以根据不同的筛选条件&#xff0c;如菜系、评价、地理位置等来选择自己想要的餐厅。 2、美食列表。针对特定餐厅&…

pandas---算术运算、逻辑运算、统计运算、自定义运算

1. Series的运算 适用于NumPy的数组运算也适用于Series。 # 基本算术运算 s 100 s - 100 s * 100 s / 100 s // 2 s ** 2 s % 2 Series之间的运算&#xff1a; 在运算中自动对齐索引&#xff1b;如果索引不对应&#xff0c;则补NaN&#xff1b;Series没有广播机制。 s3 …

Makerbase VESC 75200 AS5047P编码器测试

Makerbase VESC 75200 AS5047P编码器测试 提示&#xff1a;MKESC75200主板推荐使用VESC TOOL V3.0&#xff0c;固件版本V5.2。 第一部分 硬件介绍 1.1 硬件接口 1.2 硬件清单 序号品名数量1MKSESC 75200 V2.0主板122808电机&#xff08;带AS5047编码器&#xff09;13DC 24电…

网络安全合规-安全合规地图

网络安全行业国内本质上是合规驱动&#xff0c;但对合规的理解和尺度&#xff0c;甲方与甲方、甲方与乙方之间就有很大差别。 甲方通常来说都具有一定合规方面的积累&#xff0c;包括体系、制度、结构以及职责等等&#xff0c;如果有新的监管要求或是强制性标准发布&#xff0c…

HarmonyOS学习路之开发篇—Java UI框架(DependentLayout)

DependentLayout DependentLayout是Java UI框架里的一种常见布局。与DirectionalLayout相比&#xff0c;拥有更多的排布方式&#xff0c;每个组件可以指定相对于其他同级元素的位置&#xff0c;或者指定相对于父组件的位置。 支持的XML属性DependentLayout的共有XML属性继承自…

ASEMI代理艾赛斯IXFA14N85XHV功率MOSFET综合指南

编辑-Z 在当今世界&#xff0c;电力电子在各种应用中发挥着至关重要的作用&#xff0c;从电源和电机驱动到电动汽车和可再生能源系统。这些应用中的关键部件之一是功率MOSFET&#xff08;金属氧化物半导体场效应晶体管&#xff09;。IXFA14N85XHV是一款先进的功率MOSFET&#…

互联网医院app开发|互联网医院小程序开发

随着人们健康意识的增强&#xff0c;互联网医院系统已经成为了现代医疗服务的重要组成部分。互联网医院系统是指利用信息技术手段&#xff0c;建立具有医疗服务能力、具有与普通医院异地协同和医联体功能的综合性医疗服务平台。它可以为患者提供一系列完善的医疗服务&#xff0…

Vue3-03-Vue2 响应式 VS Vue3 响应式

本文来讲解从 Vue2 到 Vue3 响应式底层的一些改变。 前言 Vue 2.x 为什么不监听数组下标索引值的变化&#xff1f; 参考了很多博主的推文&#xff0c;自己也尝试了一下&#xff0c;Object.defineProperty 是可以做到监听数组的索引值的变化的&#xff0c;来做 getter 和 sette…

基于Yolov8的道路破损检测系统

目录 1.Yolov8介绍 2.数据集介绍 2.1数据集划分 2.2 通过voc_label.py得到适合yolov8训练需要的 2.3生成内容如下 3.训练结果分析 4. 道路破损检测系统设计 4.1 PySide6介绍 4.2 安装PySide6 4.3 道路破损检测系统设计 1.Yolov8介绍 Ultralytics YOLOv8是Ultralytics公司…

Sui x KuCoin Labs夏季黑客松|本周Workshop预告

由Sui和KuCoin Labs联合主办的夏季黑客松正如火如荼的报名中。了解黑客松详情&#xff1a;Sui与KuCoin Labs联合推出夏季黑客松&#xff0c;奖池高达28.5万美金&#xff01; &#x1f449; 黑客松官方网站&#xff1a;Sui x KuCoin Labs Summer Hackathon | Sui x KuCoin Labs…

1.2 几种常用的数制

学习目标&#xff1a; 学习几种常用的数制可以通过以下步骤进行&#xff1a; 1. 确定目标数制&#xff1a;常用的数制包括十进制、二进制、八进制和十六进制。首先&#xff0c;确定你想要学习的数制是哪一种。 2. 理解基本概念&#xff1a;了解每种数制的基本概念是非常重要…

基于云计算的java云HIS系统源码

一、一个好的HIS系统&#xff0c;要具有开放性&#xff0c;便于扩展升级&#xff0c;增加新的功能模块&#xff0c;支撑好医院的业务的拓展&#xff0c;而且可以反过来给医院赋能&#xff0c;最终向更多的患者提供更好的服务。 二、本套基于云计算的云医疗信息系统&#xff08…

【软件环境安装部署】华为云服务器下 Docker 安装 Nacos最新版并配置数据库(避雷版 最详细版 解决 Docker 容器启动 网页打不开等问题)

文章目录 拉取nacos创建挂载目录[mysql新建nacos的数据库 nacos-config&#xff0c;并执行脚本 sql脚本地址如下](https://github.com/alibaba/nacos/blob/master/config/src/main/resources/META-INF/nacos-db.sql)在/data/nacos/init.d文件夹中增加配置文件custom.properties…

SpringBoot项目实现登录验证码校验功能(可以学习,可以作为工具)

此项目只作为验证码存取演示&#xff0c;对于检验等各方面大家进行扩展就行&#xff0c;已经实现了验证码缓存&#xff0c;大家要想进行校验&#xff0c;只需要添加校验逻辑代码即可&#xff01;为了方便演示&#xff0c;直接使用了html界面进行操作&#xff0c;大家可以根据需…

【Charles】-苹果手机 IOS15.4 抓HTTPS包

写在前面 本文以Windows IOS Charles为例&#xff0c;简单说明抓包的原理&#xff0c;配置步骤以及遇到的坑。 目录 写在前面一、场景描述二、具体步骤1.环境说明2.下载Charles安装3.Charles开启代理4.手机端设置代理4.1Windows端操作4.2手机端操作 5.配置SSL5.1Charles安装S…

Html 表格标签和表单标签

表格标签 标签描述&#xff1a; <!DOCTYPE html> <html> <head><meta charset"UTF-8"><title>文档的标题</title> </head><body> <!--标识边框的宽度--> <table border"1"><thead><…

DataOps是现代数据堆栈的未来吗?

DevOps 席卷软件工程世界之前&#xff0c;一旦应用程序启动并运行&#xff0c;开发人员就会一头雾水。 工程师不是第一个知道何时发生中断&#xff0c;而是只会发现客户或利益相关者何时抱怨“网站滞后”或 503 页面过多。 不幸的是&#xff0c;这导致了同样的错误反复出现&a…