spring mvc ajax异步文件的上传和普通文件上传
表单提交方式文件上传和ajax异步文件上传
一:首先是我在spring mvc下的表单提交方式上传
ssm的包配置我就不一一详细列出来了,但是上传的包我还是列出来

这一段我也不知道怎么给大家讲解就是直接贴代码了哈
前端的代码
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>文件的上传和下载</title>
<script type="text/javascript" src="js/jquery-1.9.1.min.js"> </script>
<script type="text/javascript" src="js/jquery-form.js"> </script>
<script type="text/javascript">
</script>
</head>
<body>
<form method="POST" enctype="multipart/form-data" class="fill" action="testFileUpload4Files">
<table>
<tr>
<!-- 这里是多个文件上传 -->
<td>添加:</td>
<td><input type="file" name="file" /><br /> <input
type="file" name="file" /><br /> <input type="file" name="file" /><br />
<input type="file" name="file" /><br /></td>
</tr>
<tr>
<td>描述:</td>
<td><input type="text" name="desc" />
</td>
</tr>
<tr>
<td colspan="2"><input type="submit" value="上传" />
</td>
</tr>
</table>
</form>
</body>
</html>
这里的enctype默认是application/x-www-form-urlencoded当我们设置为multipart/form-data用以支持向服务器发送二进制数据这样我们才能上传。就是这样直接传递到服务器里面去
接下来就是支持多文件传递的服务端的代码
@RequestMapping("/testFileUpload4Files")
public String addUser(@RequestParam("file") CommonsMultipartFile[] files,
HttpServletRequest request) {
for (int i = 0; i < files.length; i++) {
System.out.println("fileName:" + files[i].getOriginalFilename());
if (!files[i].isEmpty()) {
try {
files[i].transferTo(new File("d:\\temp\\" + files[i].getOriginalFilename()));
} catch (IllegalStateException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return "/success";
}
现在就是直接选择文件提交表单就可以传递数据
二:ajax的异步文件上传
相信多数人都会提交表单方式上传文件但是遇到ajax可能有些没遇到过或者没得demo,我也是今天看了不少demo才知道可以用jquery-form.js这个插件来实现
插件里面我们可以直接调用ajaxForm实现异步上传,里面的种种方法定制上传样式就大家去实现了这里就只实现简单的上传,哈哈直接代码
前端代码
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"
contentType="text/html; charset=UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path;
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta charset="utf-8">
<title>springmvc上传文件</title>
<script type="text/javascript" src="js/jquery-1.9.1.min.js"></script>
<script type="text/javascript" src="js/jquery-form.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$("input[type='submit']").on("click", function() {
$(".fill").ajaxForm({
url : "testFileUpload4Files1", // 请求的url
type : "post", // 请求方式
dataType : "text", // 响应的数据类型
async : true, // 异步
success : function(data) {
alert(data);
},
error : function() {
alert("数据加载失败!");
}
});
});
});
</script>
</head>
<body>
<form method="POST" enctype="multipart/form-data" class="fill">
<table>
<tr>
<td>添加:</td>
<td><input type="file" name="file" /><br /> <input
type="file" name="file" /><br /> <input type="file" name="file" /><br />
<input type="file" name="file" /><br />
</td>
</tr>
<tr>
<td>描述:</td>
<td><input type="text" name="desc" /></td>
</tr>
<tr>
<td colspan="2"><input type="submit" value="上传" /></td>
</tr>
</table>
</body>
</html>
服务端我是返回他的一个文件名表示上传成功
@ResponseBody
@RequestMapping(value="/testFileUpload4Files1",produces = "text/html;charset=UTF-8")
public String ajaxUpload(@RequestParam("file") CommonsMultipartFile[] files,
HttpServletRequest request) {
StringBuffer buffer = new StringBuffer(); for (int i = 0; i < files.length; i++) {
buffer.append(files[i].getOriginalFilename());
System.out.println("fileName:" + files[i].getOriginalFilename());
if (!files[i].isEmpty()) {
try {
files[i].transferTo(new File("d:\\temp\\" + files[i].getOriginalFilename()));
} catch (IllegalStateException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return buffer.toString();
}
好的写完了 提供大家参考的主要还是源码大家可以直接看源码![]()
spring mvc ajax异步文件的上传和普通文件上传的更多相关文章
- 高性能的关键:Spring MVC的异步模式
我承认有些标题党了,不过话说这样其实也没错,关于“异步”处理的文章已经不少,代码例子也能找到很多,但我还是打算发表这篇我写了好长一段时间,却一直没发表的文章,以一个更简单的视角,把异步模式讲清楚. 什 ...
- Spring MVC的异步模式
高性能的关键:Spring MVC的异步模式 我承认有些标题党了,不过话说这样其实也没错,关于“异步”处理的文章已经不少,代码例子也能找到很多,但我还是打算发表这篇我写了好长一段时间,却一直没发表 ...
- Spring MVC的异步模式DefferedResult
原文:http://www.importnew.com/21051.html 什么是异步模式 要知道什么是异步模式,就先要知道什么是同步模式,先看最典型的同步模式: (图1) 浏览器发起请求,Web服 ...
- Spring使用ajax异步上传文件
单文件上传 <!-- 创建文件选择框 --> 文件上传 :<input type="file" id="file" name="fi ...
- Spring MVC+ajax进行信息验证
本文是一个ajax结合Spring MVC使用的入门,首先我们来了解一下什么是Ajax AJAX 不是新的编程语言,而是一种使用现有标准的新方法.AJAX 最大的优点是在不重新加载整个页面的情况下,可 ...
- Spring MVC的异步模式(ResponseBodyEmitter、SseEmitter、StreamingResponseBody) 高级使用篇
DeferredResult高级使用 上篇博文介绍的它的基本使用,那么本文主要结合一些特殊的使用场景,来介绍下它的高级使用,让能更深刻的理解DeferredResult的强大之处. 它的优点也是非常明 ...
- spring mvc对异步请求的处理
在spring mvc3.2及以上版本增加了对请求的异步处理,是在servlet3的基础上进行封装的. 1.修改web.xml <?xml version="1.0" enc ...
- spring mvc ajax 提交复杂数组类型
The server refused this request because the request entity is in a format not supported by the reque ...
- spring mvc ajax请求
jar包中增加 jackson-annotations-2.5.0.jar jackson-core-2.5.0.jar jackson-databind-2.5.0.jar springmvx.xm ...
随机推荐
- Java_6 方法
1方法的定义和使用的注意事项 方法:一些功能整合成一个功能模块 注意事项: a: 方法不能定义在另一个方法的里面 b: 写错方法名字 c: 写错了参数列表 d: 方法返回值是void,方法中可 ...
- 点线特征双目视觉SLAM---暑期笔记
1.由于以后可能研究有关基于特征方面的SLAM研究,所以近期看了一篇文章[基于点线综合特征的双目视觉SLAM方法--谢晓佳],由于之前对SLAM的模块比较模糊,所以认真阅读了此论文,并对主要的3个线程 ...
- python 创建一次性,快速的小型web服务
- Python中setup.py一些不为人知的技巧
http://python.jobbole.com/80912/ 在我开始之前,我想先说清楚我将要解释的是些“窍门”.他们不是“最好的做法”,至少在一种情况下是不可取的. 说到不可取的做法,我会适时写 ...
- Oracle_高级功能(3) synonym和database link
一.同义词synonymconnect sys/123 as sysdba;select * from emp;ORA-00942: 表或视图不存在create synonym emp for sco ...
- 使用 Spring 2.5 注释驱动的 IoC 功能
概述 注释配置相对于 XML 配置具有很多的优势: 它可以充分利用 Java 的反射机制获取类结构信息,这些信息可以有效减少配置的工作.如使用 JPA 注释配置 ORM 映射时,我们就不需要指定 PO ...
- C# web服务器被webbench攻击及目现采用的防御措施
web服务器连续两次出现CPU达到100%的情况,第一次还想着是升级时,哪个地方写错了,有死循环,最后重启了三次服务器才好. 但事后分析代码,没有死循环的可能,于是在第二次又出现CPU达100%时,仔 ...
- hdu 1541 (基本树状数组) Stars
题目http://acm.hdu.edu.cn/showproblem.php?pid=1541 n个星星的坐标,问在某个点左边(横坐标和纵坐标不大于该点)的点的个数有多少个,输出n行,每行有一个数字 ...
- Mybatis 加载 Mapper配置的四种方式
具体信息 https://blog.csdn.net/tanga842428/article/details/79285957
- RNA测序相对基因表达芯片有什么优势?
RNA测序相对基因表达芯片有什么优势? RNA-Seq和基因表达芯片相比,哪种方法更有优势?关键看适用不适用.那么RNA-Seq适用哪些研究方向?是否您的研究?来跟随本文了解一下RNA测序相对基因表达 ...