前提:Flutter 与 webview(vue) 一起开发的项目

开始的时候并没有想到什么移动端的,所以上传就用input,下载就用iframe来实现,然而真机实测的时候,input那个方法IOS支持但是安卓不支持,下载iframe那个方法则两端都不支持,于是,我们选择使用Flutter来实现.

下载功能.

首先在vue上面写个按钮触发,这里主要是用到Flutter与webview交互的方法,详情参考这里,其实主要就是在点击按钮的时候发个信号给Flutter,触发Flutter里面接收信号里面的代码.由于这里主要说上传下载,所以Flutter与webview之间的交互就略带过吧.

在Flutter里面,我是Dio+openFile来实现的,所以需要安装相关依赖dio | Dart Package 来实现下载和open_file | Flutter Package 来实现打开下载的文件这两个依赖,我是用Dio来实现下载,openfile实现下载完之后打开所下载的文件.直接在接收信号的那个方法里面调用该方法,传入实参就好了

直接贴上代码:

  void downloadFile(flowInid, fileName) async{
// 获取存储路径
String url = "http://XXX/download/fileDownload.htm?fileName=${fileName}&flowInid=${flowInid}";
print(url);
var _localPath = (await Path_provider.findLocalPath(context)) + '/Download/';
final savedDir = Directory(_localPath);
// 判断下载路径是否存在
bool hasExisted = await savedDir.exists();
// 不存在就新建路径
if (!hasExisted) {
savedDir.create();
}
Dio dio = new Dio();
//设置连接超时时间
dio.options.connectTimeout = 10000;
//设置数据接收超时时间
dio.options.receiveTimeout = 10000;
Response response = await dio.download(url, savedDir.path+fileName);
if (response.statusCode == 200) {
Navigator.pop(context);
print(savedDir.path+fileName);
String path1 = savedDir.path+fileName;
MyDiaLog.message(context, '下载成功! 存储路径是'+path1);
    OpenFile.open(path1);
//下载成功之后显示下载成功
// _controller.evaluateJavascript("uploadAfterFlutter()");
}

上传功能, 在Flutter里面,我这里主要使用 dio | Dart Package 来实现上传功能(详情点击链接看API) 和 file_picker | Flutter Package 来实现调取手机上的文件管理器

  _openFileExplorer(flowInid) async {
var fileUrl = await FilePicker.getFile();
//获取路径
setState(() {
this._file = fileUrl;
});
String path = fileUrl.path;
String fileNameShow = path.substring(path.lastIndexOf("/") + 1, path.length); // 文件名this._fileNameShow = fileNameShow;
FormData formData = FormData.from({
//"": "", //这里写其他需要传递的参数this.fileName
"file": UploadFileInfo(this._file, this._fileNameShow),
"flowInid": flowInid,
"fileName": this._fileNameShow
});
var response =
await Dio().post("http://XXXX/upload/ajaxFileUpload.htm", data: formData);
print(response);
if (response.statusCode == 200) {
print('response上传之后展示');
print(response);
_controller.evaluateJavascript("linkFlutter()"); // 上传成功之后调用的JS方法,类似刷新吧
}
}

在上传完之后的最后一个代码是调取使用webview里面的方法,具体也是看webview与Flutter的交互,上传成功是否需要执行webview某个方法视具体情境应用吧.其实在做上传下载功能的时候方法不止这种搭配,还有一个是 flutter_downloader | Flutter Package

也是可以实现的,实现方法有很多种的,具体看自己的项目吧.

Flutter,webview里面实现上传和下载的功能的更多相关文章

  1. [Android中级]使用Commons-net-ftp来实现FTP上传、下载的功能

    本文属于学习分享,如有雷同纯属巧合 利用业余时间.学习一些实用的东西,假设手又有点贱的话.最好还是自己也跟着敲起来. 在android上能够通过自带的ftp组件来完毕各种功能.这次是由于项目中看到用了 ...

  2. vue+springboot上传和下载附件功能

    https://blog.csdn.net/qq_35867245/article/details/84325385 上传附件(服务端代码) 第一步:在application.yml中配置附件要上传的 ...

  3. linux下实现ftp匿名用户的上传和下载文件功能

    1.配置/etc//vsftpd/vsftpd.conf 文件如下: 打开文件,改变如下选项,如果文件中没有该选项,需要自己手动编写该选项 write_enable=YES anonymous_ena ...

  4. ExtJS+SpringMVC文件上传与下载

    说到文件上传.下载功能,网络上大多介绍的是采用JSP.SpringMVC或者Struts等开源框架的功能,通过配置达到文件上传.下载的目地.可是最近项目要用到文件上传与下载的功能,因为本项目框架采用开 ...

  5. 基于hap的文件上传和下载

    序言 现在,绝大部分的应用程序在很多的情况下都需要使用到文件上传与下载的功能,在本文中结合hap利用spirng mvc实现文件的上传和下载,包括上传下载图片.上传下载文档.前端所使用的技术不限,本文 ...

  6. JavaWeb之文件上传和下载

    在如今的互联网时代,人们越来越喜欢将自己的数据存放到互联网上,于是便诞生了很多类型的软件,比如360网盘,百度网盘,云盘之类的.所以说,文件上传和下载的功能是现在非常主流的一个功能,应用十分广泛. 那 ...

  7. 【php】文件的上传与下载

    一. 生活中常见的地方: a) 例如邮箱.空间.文库.百度云.微爱等地方,都可以看到文件的上传和下载的应用,因此,上传和下载的功能非常重要!二. PHP当中的文件上传和下载 a) 我们需要进行一些设置 ...

  8. 全网最简单的大文件上传与下载代码实现(React+Go)

    前言 前段时间我需要实现大文件上传的需求,在网上查找了很多资料,并且也发现已经有很多优秀的博客讲了大文件上传下载这个功能. 我的项目是个比较简单的项目,并没有采用特别复杂的实现方式,所以我这篇文章的目 ...

  9. win7下利用ftp实现华为路由器的上传和下载

    win7下利用ftp实现华为路由器的上传和下载 1.  Win7下ftp的安装和配置 (1)开始->控制面板->程序->程序和功能->打开或关闭Windows功能 (2)在Wi ...

随机推荐

  1. 这是一篇每个人都能读懂的最小生成树文章(Kruskal)

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是算法和数据结构专题的第19篇文章,我们一起来看看最小生成树. 我们先不讲算法的原理,也不讲一些七七八八的概念,因为对于初学者来说,看到 ...

  2. C:__attribute__ weak 的作用

    关于 weak weak经常出现在各种c代码中,其作用是将当前文件的对应函数声明为弱函数符号,如果外部文件出现相同的函数名,最终编译出来的 文件会优先指向外部文件的函数符号: 通常需要使用__attr ...

  3. Awareness Kit让你的音乐APP脱颖而出,更懂用户,也更动人心

    让你的音乐APP脱颖而出,更懂用户,也更动人心. 场景 情景感知服务能带来什么?   作为音乐发烧友,闲下来的时候总想打开App,享受沉浸在音乐中的放松.然而,App推荐的歌单经常没法满足我的需要,如 ...

  4. [CodeForces 300C Beautiful Numbers]组合计数

    题意:十进制的每一位仅由a和b组成的数是“X数”,求长度为n,各数位上的数的和是X数的X数的个数 思路:由于总的位数为n,每一位只能是a或b,令a有p个,则b有(n-p)个,如果 a*p+b*(n-p ...

  5. [codeforces 200 A Cinema]暴力,优化

    题意大致是这样的:有一个有n行.每行m个格子的矩形,每次往指定格子里填石子,如果指定格子里已经填过了,则找到与其曼哈顿距离最小的格子,然后填进去,有多个的时候依次按x.y从小到大排序然后取最小的.输出 ...

  6. [hdu3364]xor方程组消元

    题意:n个灯,m个开关,给定每个开关控制的灯,全部的灯初始时全部熄灭,开关按一下其所控制的灯的状态全部反转,开关最多只能按一下.问达到目标状态的方案数. 思路:xor方程组的模型. 1 2 3 4 5 ...

  7. 在一段字符串中的指定位置插入html标签,实现内容修改留痕

    客户需求:实现内容修改留痕,并且鼠标移动到元素时,显示修改人和修改时间. (其实呢本人觉得这个如果是静态的页面,或者是后端拼接好的html,都很好实现,如果让前端动态实现就......) 前端实现的方 ...

  8. C# 委托delegate的基本用法

    委托:就是一个方法的类型,下面3个调用情况来详细熟悉一下: 1.调用组合委托 //委托:就是一个方法的类型 public delegate int TestDelegateStr(); public ...

  9. Qt标准对话框按钮文字等设置为中文

    问题描述:QMessageBox.QColorDialog等标准对话框按钮显示都是英文 设置中文方法如下: 1)拷贝Qt安装目录下的qt_zh_CN.qm和qt_zh_CN.ts文件到工程目录中 2) ...

  10. zookeeper和Eureka的区别

    RDBMS==>(MySql,Oracle,SqlServer等关系型数据库)遵循的原则是:ACID原则 A:Atomicity 原子性 C:Consistency 一致性 I:Isolatio ...