转自: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. linux-RabbitMQ安装命令

    一.RabbitMQ 1.安装配置epel源    $ rpm -ivh http://dl.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.no ...

  2. Python staticmethod

    1 @staticmethod 静态方法 when this method is called, we don't pass an instance of the class to it (as we ...

  3. Java String.split()用法小结(转载)

    在java.lang包中有String.split()方法,返回是一个数组 我在应用中用到一些,给大家总结一下,仅供大家参考: 1.如果用“.”作为分隔的话,必须是如下写法,String.split( ...

  4. review23

    文件的创建与删除 当使用File类创建一个文件对象后,例如 File file = new File("C:\\myletter", "letter.txt") ...

  5. spring: 在表达式中使用类型

    如果要在SpEL中访问类作用域的方法和常量的话,要依赖T()这个关键的运算符.例如,为了在SpEL中表达Java的Math类,需要按照如下的方式使用T()运算符: T{java.lang.Math} ...

  6. node——路由控制

    路由控制 前面我接触了如何使用express建立一个工程,虽然这个工程包含了一些基本的框架,但是没有实际内容,我们会不断给他增加的. 工作原理 我们在浏览器中访问app.js建立的服务器时,会出现一个 ...

  7. 如何在windows上部署war包到tomcat服务器

    一. 什么是war包 WAR(Web Archive file)网络应用程序文件,是与平台无关的文件格式,它允许将很多文件组合成一个压缩文件.war专用在web方面,一个war包可以理解为一个web项 ...

  8. Xcode Developer Tools

    打开Xcode,执行菜单命令 Xcode - Open Developer Tool - More Developer Tools... 会打开苹果开发者中心的工具下载页面. 这里包含了xcode未安 ...

  9. 吐槽XE3中的BUG:无法调试32位的应用程序

    我想用的功能在XE5中有BUG, 无奈转移到XE3中测试,发现了XE3还有另外一个问题:无法DEBUG 32位的应用程序,这算什么事啊?有人说把项目属性中的link with dynamic RTL去 ...

  10. Pdf 解密后复制文字乱码

    1.安装cajviewer 这个工具 2.用CAJviewer打开pdf文档 3.选择图像4.点文字识别,这时候就弹窗一个框,里面是可复制的文本,而且准确率比较高