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 ...
随机推荐
- Tomcat登陆mysql的密码设置
在登陆mysql的密码和数据库密码不一致时,可以修改Mysql数据库密码或者修改连接Mysql的配置文件: 1.修改连接Tomcat里连接Mysql的配置文件 需要修改两个配置文件 ,一个是在tom ...
- win下Apache2.4的下载与安装
1.到apache官网上下载apache的安装文件 http://httpd.apache.org/download.cgi 点击链接Files for Microsoft Windows,因为a ...
- threejs- z-fighting 问题(模型的重叠部位便不停的闪烁起来。这便是Z-Fighting问题)
Z-Buffer 在threejs中,使用深度缓冲(Z-Buffer)来完成场景可见性计算,即确定场景哪部分可见,哪部分不可见.深度缓冲(Z-Buffer)是一个二维数组,其中的每一个元素对应屏幕上的 ...
- sql 查询某个字段出现的次数
表名随便起个 testtable 那么有这么一个需求,利用你所学的sql语句 单表查询出下表的结果 也就是统计某个时间某个值出现的次数其实一开始我是很懵,毕竟之前也没做过,只能怪自己学得太浅了.过后我 ...
- L1-033 出生年(15)(STL-set代码)
L1-033 出生年(15 分) 以上是新浪微博中一奇葩贴:"我出生于1988年,直到25岁才遇到4个数字都不相同的年份."也就是说,直到2013年才达到"4个数字都不相 ...
- iOS.AutoLayout.2.CustomView-with-AutoLayout
Custom View Which Support AutoLayout 创建支持AutoLayout的Custom View AutoLayout 通过使view更加的自组织来减轻controlle ...
- Java的OOP三大特征之一——封装
面向对象三大特征之一 封装 继承 多态 封装性就是把类(对象)的属性和行为结合成一个独立的相同单位,并尽可能隐蔽类(对象)的内部细节,对外形成一个边界,只保留有限的对外接口使之与外部发生联系. ...
- the example of dlsym
void *handle; int i, (*fptr)(int); /* open the needed object */ handle = dlopen("/usr/home/me/l ...
- EL 11个内置对象
JSP开发人员可以在EL表达式中使用EL隐式对象,而不用任何显式的编码或声明.语法如下: ${隐式对象名} <!-- 获取EL隐式对象的引用 --> 在JSP页面中,可以使用JSP脚本来 ...
- Web 文件上传方面的安全问题
一. 文件上传漏洞与WebShell的关系 文件上传漏洞是指网络攻击者上传了一个可执行的文件到服务器并执行.这里上传的文件可以是木马,病毒,恶意脚本或者WebShell等.这种攻击方式是最为直接和有效 ...