Html5实现文件异步上传功能


Posted in HTML / CSS onMay 19, 2017

1 简介

开发文件上传功能从来不是一件愉快的事,异步上传更是如此,使用过iframe和Flash的上传方案,也都感觉十分的别扭。本文简要简绍利用Html5的FormData实现文件的异步上传,还可以实现上传进度条和文件大小验证等。服务端使用springMVC的方案进行处理。

2 Html代码

<form id="myForm">
    <input type="file" id="u_photo" name="u_photo" />
    <input type="button" id="submit-btn" value="上传" />
</form>

3 JQuery上传

$("#submit-btn").on('click', function() {
    $.ajax({
        url:"/test/upload",
        type:"post",
        data:new FormData($("#myForm").get(0)),
        //十分重要,不能省略
        cache: false,
        processData: false,
        contentType: false,
        success: function () {
            alert("上传成功!");
        }
    });
});

4 JQuery文件大小验证

文件大小的及相应行为的控制,需根据需要自行处理,本方法只是示例方法。

$('#u_photo').on('change', function() {
    var file = this.files[0];
    if (file.size > 1024*1000) {
        alert('文件最大1M!')
    }
});

5 JQuery进度条

在ajax方法中加入xhr即可控制上传进度,进度条可以使用html5的progress也可使用其它的进度条。显示及隐藏进度条需要自行处理,本方法只是简单介绍了进度条的基本控制。

xhr: function() {
    var myXhr = $.ajaxSettings.xhr();
    if (myXhr.upload) {
        myXhr.upload.addEventListener('progress', function(e) {
            if (e.lengthComputable) {
                $('progress').attr({
                    value: e.loaded,
                    max: e.total,
                });
            }
        } , false);
    }
    return myXhr;
}

6 springMVC服务端

6.1 maven依赖

<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.5</version>
</dependency>
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.3.2</version>
</dependency>

6.2 servlet-context.xml

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver" />

6.3 Controller

示例程序,并未给出文件验证,存储及处理的相应代码。

@RequestMapping(value="/test/upload",method = RequestMethod.POST)
@ResponseBody
public String upload(@RequestParam("u_photo") MultipartFile u_photo) {
    System.out.println("u_photo="+u_photo.getSize());
    return "ok";
}

7 兼容性

IE 10+, Firefox 4.0+, Chrome 7+, Safari 5+, Opera 12+

8 推荐阅读

如果对上述方案不满意,推荐使用如下的解决方案:

JQuery File Uploader

以上所述是小编给大家介绍的Html5实现文件异步上传功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

HTML / CSS 相关文章推荐
CSS3用@font-face实现自定义英文字体
Sep 23 HTML / CSS
使用CSS Grid布局实现网格的流动
Dec 30 HTML / CSS
css3动画效果小结(推荐)
Jul 25 HTML / CSS
CSS3 animation实现简易幻灯片轮播特效
Sep 27 HTML / CSS
css3实现平移效果(transfrom:translate)的示例
Nov 13 HTML / CSS
利用HTML5中Geolocation获取地理位置调用Google Map API在Google Map上定位
Jan 23 HTML / CSS
HTML5对比HTML4的主要改变和改进总结
May 27 HTML / CSS
使用HTML5里的classList操作CSS类
Jun 28 HTML / CSS
浅谈HTML5 &amp; CSS3的新交互特性
Jul 19 HTML / CSS
html5录音功能实战示例
Mar 25 HTML / CSS
使用html5实现表格实现标题合并的实例代码
May 13 HTML / CSS
关于解决iframe标签嵌套问题的解决方法
Mar 04 HTML / CSS
Html5新标签datalist实现输入框与后台数据库数据的动态匹配
May 18 #HTML / CSS
HTML5中indexedDB 数据库的使用实例
May 11 #HTML / CSS
详解HTML5 window.postMessage与跨域
May 11 #HTML / CSS
HTML5拖放API实现拖放排序的实例代码
May 11 #HTML / CSS
解决html5中video标签无法播放mp4问题的办法
May 07 #HTML / CSS
Web前端页面跳转并取到值
Apr 24 #HTML / CSS
HTML5新特性 多线程(Worker SharedWorker)
Apr 24 #HTML / CSS
You might like
Yii框架中memcache用法实例
2014/12/03 PHP
Composer设置忽略版本匹配的方法
2016/04/27 PHP
php精度计算的问题解析
2019/06/21 PHP
JQuery 入门实例1
2009/06/25 Javascript
jquery使整个div区域可以点击的方法
2015/06/24 Javascript
jQuery树形控件zTree使用小结
2016/08/02 Javascript
nodeJs内存泄漏问题详解
2016/09/05 NodeJs
js获取css的各种样式并且设置他们的方法
2017/08/22 Javascript
关于layui的动态图标不显示的解决方法
2019/09/04 Javascript
浅谈监听单选框radio改变事件(和layui中单选按钮改变事件)
2019/09/10 Javascript
微信小程序实现分享商品海报功能
2019/09/30 Javascript
vue中音频wavesurfer.js的使用方法
2020/02/20 Vue.js
JS面向对象编程基础篇(三) 继承操作实例详解
2020/03/03 Javascript
基于node+websocket+html实现腾讯课堂聊天室聊天功能
2020/03/04 Javascript
node运行js获得输出的三种方式示例详解
2020/07/02 Javascript
vue实现移动端项目多行文本溢出省略
2020/07/29 Javascript
el-form 多层级表单的实现示例
2020/09/10 Javascript
JS中循环遍历数组的四种方式总结
2021/01/23 Javascript
vue 组件基础知识总结
2021/01/26 Vue.js
[01:35]2014DOTA2西雅图邀请赛 专访狐狸妈青春献给刀塔
2014/07/08 DOTA
python数据结构之图的实现方法
2015/07/08 Python
Python的“二维”字典 (two-dimension dictionary)定义与实现方法
2016/04/27 Python
实例讲解python中的协程
2018/10/08 Python
对python:循环定义多个变量的实例详解
2019/01/20 Python
python常见字符串处理函数与用法汇总
2019/10/30 Python
Python获取、格式化当前时间日期的方法
2020/02/10 Python
CSS3属性使网站设计增强同时不消弱可用性
2009/08/29 HTML / CSS
Myprotein俄罗斯官网:欧洲第一运动营养品牌
2019/05/05 全球购物
乌克兰机票、铁路和巴士票、酒店搜索、保险:Tickets.ua
2020/01/11 全球购物
动态密码技术
2012/10/18 面试题
分家协议书
2014/04/21 职场文书
委托书如何写
2014/08/30 职场文书
英语教师个人工作总结
2015/02/09 职场文书
药房管理制度范本
2015/08/06 职场文书
导游词之山东八大关
2019/12/18 职场文书
Python MNIST手写体识别详解与试练
2021/11/07 Python