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的新特性介绍
Oct 31 HTML / CSS
CSS3教程(7):CSS3嵌入字体
Apr 02 HTML / CSS
用纯css3实现的图片放大镜特效效果非常不错
Sep 02 HTML / CSS
纯css3实现宠物小鸡实例代码
Oct 08 HTML / CSS
详解CSS3+JS完美实现放大镜模式
Dec 03 HTML / CSS
CSS3.0实现霓虹灯按钮动画特效的示例代码
Jan 12 HTML / CSS
HTML5 canvas基本绘图之绘制矩形
Jun 27 HTML / CSS
HTML5中新标签和常用标签详解
Mar 07 HTML / CSS
HTML5使用drawImage()方法绘制图像
Jun 23 HTML / CSS
详解移动端HTML5页面端去掉input输入框的白色背景和边框(兼容Android和ios)
Dec 15 HTML / CSS
AmazeUI 点击元素显示全屏的实现
Aug 25 HTML / CSS
HTML5页面打开微信小程序功能实现
Sep 23 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
PHP GD 图像处理组件的常用函数总结
2010/04/28 PHP
百度地图API应用之获取用户的具体位置
2014/06/10 PHP
详解EventDispatcher事件分发组件
2016/12/25 PHP
JS模拟多线程
2007/02/07 Javascript
JavaScript中的cacheStorage使用详解
2015/07/29 Javascript
node.js平台下利用cookie实现记住密码登陆(Express+Ejs+Mysql)
2017/04/26 Javascript
详解Vue2.X的路由管理记录之 钩子函数(切割流水线)
2017/05/02 Javascript
详解javascript 正则表达式之分组与前瞻匹配
2018/05/30 Javascript
vue2实现搜索结果中的搜索关键字高亮的代码
2018/08/29 Javascript
vue实现的树形结构加多选框示例
2019/02/02 Javascript
js使用cookie实现记住用户名功能示例
2019/06/13 Javascript
JavaScript Event Loop相关原理解析
2020/06/10 Javascript
[01:06:19]DOTA2-DPC中国联赛定级赛 LBZS vs SAG BO3第二场 1月8日
2021/03/11 DOTA
Python写的一个简单监控系统
2015/06/19 Python
Python轻量级ORM框架Peewee访问sqlite数据库的方法详解
2017/07/20 Python
Python 判断 有向图 是否有环的实例讲解
2018/02/01 Python
用python与文件进行交互的方法
2018/03/01 Python
pandas 空的dataframe 插入列名的示例
2018/10/30 Python
python实现微信定时每天和女友发送消息
2019/04/29 Python
Python英文文章词频统计(14份剑桥真题词频统计)
2019/10/13 Python
详解Python可视化神器Yellowbrick使用
2019/11/11 Python
详解python环境安装selenium和手动下载安装selenium的方法
2020/03/17 Python
Python ArgumentParse的subparser用法说明
2020/04/20 Python
Python StringIO及BytesIO包使用方法解析
2020/06/15 Python
Python操作dict时避免出现KeyError的几种解决方法
2020/09/20 Python
CSS3实现淘宝留白的方法
2020/06/05 HTML / CSS
Qoo10马来西亚:全球时尚和引领潮流的购物市场
2016/08/25 全球购物
企业演讲稿范文
2013/12/28 职场文书
关于抽烟的检讨书
2014/02/25 职场文书
幼儿园毕业寄语
2014/04/03 职场文书
计算机专业自荐信
2014/05/24 职场文书
单位授权委托书范本
2014/09/26 职场文书
2014年学生会生活部工作总结
2014/11/07 职场文书
认识实习感想
2015/08/10 职场文书
使用tensorflow 实现反向传播求导
2021/05/26 Python
基于Go语言构建RESTful API服务
2021/07/25 Golang