html大文件传输教程

文件上传是最古老的互联网操作之一,20多年来几乎没有怎么变化,还是操作麻烦、缺乏交互、用户体验差。

一、前端代码

* iframe上传
   * ajax上传
   * 进度条
   * 文件预览
   * 拖放上传

文件上传的传统形式,是使用表单元素file,参考 http://www.ruanyifeng.com/blog/2012/08/file_upload.html :


所有浏览器都支持上面的代码,点击上传按钮后,网页”锁死”,用户只能等待上传结束,然后浏览器刷新,跳到表单的action属性指定的网址。

用户点击submit时,动态插入一个iframe元素

var form = $(“#upload-form”);

form.on(‘submit’,function() {

// 此处动态插入iframe元素

});

var seed = Math.floor(Math.random() * 1000);

var id = “uploader-frame-” + seed;

var callback = “uploader-cb-” + seed;

var iframe = $(‘

var url = form.attr(‘action’);

form.attr(‘target’, id).append(iframe).attr(‘action’, url + ‘?iframe=’ + callback);

form.on(‘submit’,function() {

// 此处进行ajax上传

});

// 检查是否支持FormData

if(window.FormData) {

var formData = new FormData();

// 建立一个upload表单项,值为上传的文件

formData.append(‘upload’, document.getElementById(‘upload’).files[0]);

var xhr = new XMLHttpRequest();

xhr.open(‘POST’, $(this).attr(‘action’));

// 定义上传完成后的回调函数

xhr.onload = function () {

if (xhr.status === 200) {

console.log(‘上传成功’);

} else {

console.log(‘出错了’);

xhr.send(formData);

//在页面中放置一个HTML元素progress

//定义进度progress事件的回调函数

xhr.upload.onprogress = function (event) {

if (event.lengthComputable) {

var complete = (event.loaded / event.total * 100 | 0);

var progress = document.getElementById(‘uploadprogress’);

progress.value = progress.innerHTML = complete;

Spring 框架中使用类似CommonsMultipartFile对象处理表二进制文件信息,细心地会发现在利用框架下封装的Multiform接口进行文件上传时,会先把文件传输至tomcat一个指定的work目录之下,然后再传输到指定的路径。小文件上传这个时间延迟基本上可以忽略,但是在大文件上传时,这个上传的速度就很让人头疼,上传过程中的进度信息无法访问。

因此我们有必要从浏览器请求字节流中解析Multiform协议,实现不依靠框架内置对象,取得用户请求的所有数据,同时,用户上传的大小不受限制,而且在传输过程中,我们可以实时获取传输进度。

参考https://www.cnblogs.com/darkprince/p/5114936.html

因为一次传输的大文件MultiPart数据包,字节数可能会很大(1G甚至以上),为了获取实时进度信息,以及内存开销控制,我们需要将接收过程分成多段处理,即将数据包分段循环接收(例:每次循环只接收64K数据,期间即可更新当前的进度信息)。本次我们采用Spring框架来实现”大文件传输”功能,要点设计结构图如下:

2.2 源码解析

Filter对象:

用于负责接收MultiPart原始数据的Filter,用以在Spring内置对象之前接收用户请求。需要在Web.xml中进行配置,Web启动后,该Filter即启动,当用户请求到来时需要判断该MultiPart数据信息是否合法,接收并进行解析。

ServletInputStream/BufferedInputStream对象:

使用以上两对象,可对本次请求进行按字节流接收。在此可创建比较小的接收缓冲区,依靠BufferedInputStream的read进行分段循环接收。

getBoundarySectFromBuf()函数:

自定义函数,我们需要该函数从分段缓冲区中分析可能包含的多个Form表单信息,或者部分表单信息,或者二进制文件片段信息。对于表单信息分析后填充表单数据结构,对于二进制文件信息需要写文件。该函数需要完成边接收边解析边写文件的重要工作。

ProgressInfo对象:

进度信息类,描述了一次上传请求的进度信息。该对象会用来被客户端轮询请求,以获得当前传输大文件过程中的进度信息。

FormPart对象及listFormPart集合:

FormPart对于单个Form表单的描述。listFormPart为本次请求的全部表单描述集合。即供后续代码调用的全部表单项内容。

Controller层getProgInfo()处理函数:

该函数将接受来自浏览器的”获得进度信息请求”,并从当前ServletContext公共内存区中找到与Progesss ID对应的进度信息对象ProgressInfo,以XML的形式返回给浏览器。该函数会被客户端轮询请求。

欢迎入群一起讨论”374992201″

Original: https://www.cnblogs.com/songsu/p/14919005.html
Author: Xproer-松鼠
Title: html大文件传输教程

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/546090/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • djangomodelform

    python view.py class UserModelForm(forms.ModelForm): class Meta: model = models.UserInfo f…

    技术杂谈 2023年7月24日
    081
  • Bot Style Tests VS Page Objects

    Bot Style Tests 一个 bot是基于Selenium APIs 面向操作的抽象。这意味着如果你发现命令对你的应用程序没有做正确的事情,改变他们很容易。 bst.py …

    技术杂谈 2023年5月31日
    075
  • []产品和成本效率总结提炼

    [原创]产品和成本效率总结提炼 1、个人的成本和效率: 对外(你的产品帮用户降低成本,提升效率)和对内(你的方法有没有更好的方案,如:天猫精灵,解决了必须要用手机控制设备) 2、组…

    技术杂谈 2023年5月30日
    099
  • Git的基本使用

    基础操作 1.选择一个合适的地方,创建一个新目录 mkdir learngit cd learngit 2.通过 git init命令把这个目录变成Git可以管理的仓库 git i…

    技术杂谈 2023年7月24日
    070
  • Centos7: 防火墙相关

    防火墙 开放端口 firewall-cmd –zone=public –add-port=5672/tcp –permanent # 开&#x6…

    技术杂谈 2023年7月24日
    053
  • 利用docker部署oxidized网络设备备份系统

    随着网络设备的增多,通过人手备份网络设备倍感压力,而且效率低。有编程基础的人可能会通过Python的parimiko 或者netmiko 连接到设备操作 把文件通过ftp 上传到F…

    技术杂谈 2023年6月21日
    092
  • Win10关闭自动播放

    新文章 Win10关闭自动播放 所有设置-设备-自动播放-关闭就可以了。 posted on2022-06-17 23:58 宏宇 阅读(263 ) 评论() 编辑 Origina…

    技术杂谈 2023年5月31日
    0107
  • 【HarmonyOS】【ARK UI】HarmonyOS ets语言怎么实现双击返回键退出

    ​ 参考资料 【Harmony OS】【ARK UI】Date 基本操作 自定义组件生命周期回调函数 弹窗 代码运行 思路: 定义一个全局变量,判断点击时间与上一次点击时间差,若大…

    技术杂谈 2023年5月31日
    084
  • Prometheus由于时间不同步导致数据不显示

    原文链接:Prometheus由于时间不同步导致数据不显示 问题 部署 prometheus 后,访问前端界面发现: 这是由于你windows机器与部署prometheus服务器的…

    技术杂谈 2023年7月25日
    074
  • MyBatisPlus 入门教程,这篇很赞

    在之前的文章中我们经常使用MybatisPlus进行增删改查,可能有些小伙伴对mybatisplus不是很熟悉,今天特意出了一般入门级的教程,我自己也是一边学习一边写的,有什么地方…

    技术杂谈 2023年6月21日
    0135
  • React学习资料

    以下是我整理的React学习资料,包括:React基础、Redux、reat-router, redux middleware, higher order components, …

    技术杂谈 2023年5月31日
    077
  • WebSocket

    WebSocketConfig.java /** * WebSocket配置类 * @author admin *…

    技术杂谈 2023年6月21日
    099
  • 【Elasticsearch】查询并删除匹配文档之_delete_by_query

    思路:先查询确认,后精准删除 假设我想删除title是”小明今晚真的不加班”这条记录,先查看一下现有的记录: (不加班不好吗?为什么要删除呢?) tips:…

    技术杂谈 2023年7月24日
    056
  • mongodb压力测试工具ycsb

    mongodb安装 这里以安装单机版为例,rpm包方式安装 启动 ​ systemctl start mongod YCSB压测工具安装 这里不采用网上大多说的maven方式源码安…

    技术杂谈 2023年7月11日
    065
  • Mac m1 安装 swoole

    下载 swoole最新版 https://pecl.php.net/package/swoole sudo /opt/homebrew/Cellar/php@7.3/7.3.32/…

    技术杂谈 2023年5月30日
    082
  • JZ0047:二叉树剪支

    title:二叉树剪支 📃 题目描述 题目链接:二叉树剪支、相同题目 🔔 解题思路 第一种做法:dfs,思考方式是你站在一个点上怎么做,在一个点上,先看左子树是否要删除,再看看右子…

    技术杂谈 2023年7月24日
    073
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球