html ajax 上传文件到服务器,Ajax文件异步上传,Html5实现

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

1 简介

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

2 Html代码

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依赖

commons-io

commons-io

2.5

commons-fileupload

commons-fileupload

1.3.2

6.2 servlet-context.xml

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+

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值