转自:https://www.jianshu.com/p/f3987f0f471f

今天,我就这个问题来写一篇如何用 SpringMVC + AJAX 实现的多文件异步上传功能。基本的代码还是沿用上篇文章中所用到的项目,需要的朋友可以点击前面的链接查看。在这里只贴出关键代码。

首先我们要准备一个 JS 文件,即:ajaxfileupload.js,它需要用到 jQuery,所以我们还需要准备 jQuery 的库,两个文件在文末尾都有链接提供下载。

JSP 关键代码:

<li>
<div>
<input type="file" id="file1" name="imgFile" /><span class="uploadStatus"></span>
</div>
<div>
<input type="file" id="file2" name="imgFile" /><span class="uploadStatus"></span>
</div>
<input type="button" onclick="ajaxUpload();" value="上传文件"/><br />
</li>

两个 file input 标签的 name 是一致的“imgFile”,方便 SpringMVC 在 controller 层接收。每个 input 标签后面跟一对 span 标签,用于显示上传结果。
最后提供一个 button 按钮,点击事件 onclick 执行下面我们即将写的 JS 函数。

JS 关键代码:

<script src="js/jquery-2.1.0.js" type="text/javascript"></script>
<script src="js/ajaxfileupload.js" type="text/javascript"></script>
<script type="text/javascript">
// 多文件异步上传
function ajaxUpload(){
$("input[type=file]").each(function(){
var fileEleId = $(this).attr("id");
// 单个文件的异步上传
$.ajaxFileUpload({
url : 'user/ajaxUpload', // 用于文件上传的服务器端请求地址
fileElementId : fileEleId, // 对应文件上传标签的 id 属性
type : 'post',
dataType : 'text', //返回值类型
success : function(data, status) {
document.getElementById(fileEleId).nextSibling.innerHTML ="上传成功";
},
error : function(data, status, e) {
document.getElementById(fileEleId).nextSibling.innerHTML ="上传失败";
}
});
});
}
</script>

在循环中引用了 $.ajaxFileUpload 方法,这就是用来异步上传文件用的方法啦!看结构是不是与 jQuery 的 $.ajax 很像呢?需要注意的是 fileElementId 这个参数,用于指定即将上传文件的 input file 的标签 ID。最后在 success 函数中指定回传状态的显示结果就可以了。JSP 部分的代码到此结束,是不是很简单呢!

然后再来看对应 Controller 层代码,我们接着在上篇文章中用到的 UserController 类中写映射方法。
Java 代码:

    /**
* 文件异步上传请求处理
* @param request
* @return 上传结果:success、failed
*/
@RequestMapping(value = "ajaxUpload", method = RequestMethod.POST)
public @ResponseBody
String ajaxUpload(HttpServletRequest request) {
MultipartHttpServletRequest multipartRequest
= (MultipartHttpServletRequest) request;
// 获取input file对应的 name 的文件
MultipartFile mFile = multipartRequest.getFile("imgFile");
String path = "D:\\testFile\\"; // 保存的文件位置
String fileName = mFile.getOriginalFilename();
// 上传的图片所保存在服务器上的位置
String outPath = path + fileName;
try(OutputStream outputStream = new FileOutputStream(outPath);
InputStream inputStream = mFile.getInputStream();){
byte[] buffer = new byte[4096];
int length = 0;
while((length = inputStream.read(buffer)) != -1){
outputStream.write(buffer, 0, length);
}
} catch (IOException ioe){
logger.info("File Upload Exception...", ioe);
return "failed";
}
return "success";
}

这样就OK了!
当然了,文件上传好了之后,我们还需要记录保存文件的 URL 路径到数据库中,有一个比较好的思路:将保存文件的URL返回给前端 JSP,然后在 JSP 上创建 hidden 隐藏表单域,将 URL 填写到 隐藏表单域中,提交表单时,直接传递 URL 给后端保存即可。

作者:uzip柚子皮
链接:https://www.jianshu.com/p/f3987f0f471f
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

SpringMVC + AJAX 实现多文件异步上传的更多相关文章

  1. Ajax简单实现文件异步上传的多种方法

    1. 认识FormData对象 FormData是Html5新加进来的一个类,可以模拟表单数据 构造函数 FormData (optional HTMLFormElement form) (可选) 解 ...

  2. 文件的上传(表单上传和ajax文件异步上传)

    项目中用户上传总是少不了的,下面就主要的列举一下表单上传和ajax上传!注意: context.Request.Files不适合对大文件进行操作,下面列举的主要对于小文件上传的处理! 资源下载: 一. ...

  3. 普通文件的上传(表单上传和ajax文件异步上传)

    一.表单上传: html客户端部分: <form action="upload.ashx" method="post" enctype="mul ...

  4. 文件的上传(1)(表单上传和ajax文件异步上传)

    文件的上传(表单上传和ajax文件异步上传) 项目中用户上传总是少不了的,下面就主要的列举一下表单上传和ajax上传!注意: context.Request.Files不适合对大文件进行操作,下面列举 ...

  5. HTML5实现图片文件异步上传

    原文:HTML5实现图片文件异步上传 利用HTML5的新特点做文件异步上传非常简单方便,本文主要展示JS部分,html结构.下面的代码并未使用第三发库,如果有参照,请注意一些未展现出来的代码片段.我这 ...

  6. js 文件异步上传 显示进度条 显示上传速度 预览文件

    通常文件异步提交有几个关键 1.支持拖拽放入文件.2.限制文件格式.3.预览图片文件.4.上传进度,速度等,上传途中取消上传.5.数据与文件同时上传 现在开始笔记: 需要一个最基础的元素<inp ...

  7. MVC文件上传04-使用客户端jQuery-File-Upload插件和服务端Backload组件实现多文件异步上传

    本篇使用客户端jQuery-File-Upload插件和服务端Badkload组件实现多文件异步上传.MVC文件上传相关兄弟篇: MVC文件上传01-使用jquery异步上传并客户端验证类型和大小  ...

  8. 小程序使用 Promise.all 完成文件异步上传

    小程序使用 Promise.all 完成文件异步上传 extends [微信小程序开发技巧总结(二) -- 文件的选取.移动.上传和下载 - Kindear - 博客园 (cnblogs.com)] ...

  9. 使用FormData实现ajax文件异步上传

    1.传统的web开发文件上传一般是基于form表单的文件上传,同步的方式,用户体验差,可控性也差 2.异步上传的实现 有以下方式 2.1 借助浏览器插件 一般需要安装一些类似flash的插件  这种方 ...

随机推荐

  1. 更改jmeter发送邮件样式(转)

    http://www.cnblogs.com/puresoul/p/5049433.html Jmeter默认的报告展示的信息比较少,如果出错了,不是很方便定位问题.由Jmeter默认报告优化这篇文章 ...

  2. NovaException: Unexpected vif_type=binding_failed

    nova/virt/libvirt/vif.py: _("Unexpected vif_type=%s") % vif_type) NovaException: Unexpecte ...

  3. Switching from Redhat Linux to Oracle Linux in about 5,000 easy steps

    Wayback When I remember being at Oracle Open World when Larry Ellison unveiled Oracle Enterprise Lin ...

  4. idea使用git上传项目到coding

    1.VCS -> import into version control -> create git repository 2.选择要上传的项目根目录 3.选择后,项目里的文件名字变成了绿 ...

  5. 《领域驱动设计 C# 2008 实现》 - 书摘精要

    (P2) 智能客户反模式被 Eric Evans 定义为“把所有业务逻辑放进用户界面.把系统分解成小函数,作为分离的用户界面实现,并在里面嵌入业务规则.使用关系数据库作为共享的数据仓储.使用现有的自动 ...

  6. 不能解决,复选框在request对象获取的信息后显示在用户信息里面为中文的选项名

    因为方框里面value 不用中文?.? 假如用中文呢?  完全可以!!已经试验 如果不用中文,那么中文可以用对象的参数来获得,即在login.jsp中就要用javabean类属性

  7. 浅学soap--------4

    引入nusoap Service.php //运行该文件,在网页中wsdl点击,可浏览生成的wsdl代码;网页提供注册的方法 <?php require_once ("nusoap/n ...

  8. an easy problem(贪心)

    An Easy Problem Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8333   Accepted: 4986 D ...

  9. python沉淀之路~~整型的属性

    python的基础知识: 基本数据类型:int   str   list   tuple   dict   bool 一.整型的属性功能 1.工厂方法将字符串转换成整型 a = " b = ...

  10. vue 链接

    https://www.jianshu.com/p/5d9b341d650f vue-cli入门(三)——人员管理实例 ps:如何创建vue-cli项目 https://www.v2ex.com/t/ ...