SpringMVC转发与重定向、文件上传
一、重定向
-----在一个请求处理方法Action中如果返回结果为“index”字符则表示转发到视图index,有时候我们需要重定向,则可以在返回的结果前加上一个前缀“redirect:”,可以重定向到一个指定的页面,也可以是另一个action
重定向URL地址会发生改变。
会发送两次请求。
为了保持action3中的数据Spring MVC自动将数据重写到了url中。为了实现重定向时传递复杂数据,可以使用Flash属性,示例代码如下:
@Controller
@RequestMapping("/foo")
public class FPController {
// 重定向
@RequestMapping("/action2")
public String action2(Model model) {
return "index";
}
@RequestMapping("/action3")
public String action3(Model model) {
model.addAttribute("message", "action3Message");
return "redirect:action2";
}
当请求http://localhost:8080/MVCTest/foo/action3时运行结果如下:
// 接收重定向参数
@RequestMapping("/action2")
public String action2(Model model, Product product) {
model.addAttribute("message", product);
System.out.println(model.containsAttribute("product")); // true
return "foo/index";
}
//重定向属性
@RequestMapping("/action3")
public String action3(Model model, RedirectAttributes redirectAttributes) {
Product product = new Product(2, "iPhone7 Plus", 6989.5);
redirectAttributes.addFlashAttribute("product", product);
return "redirect:action2";
}
当访问action3时,首先创建了一个product产口对象,将该对象添加到了Flash属性中,在重定向后取出,个人猜测应该暂时将对象存入了Session中。当请求foo/action3时运行结果如下:
url地址已经发生了变化,product对象其实也已经被存入了model中,在action的视图中可以直接拿到。
二、转发
str=”forward : 路径” 请求转发到一个页面中
str=”forward : controller的映射” 请求转发到一个controller方法中
//11.转发
@RequestMapping("/act11")
public String act11(Model model){
return "hi";
}
//12.转发
@RequestMapping("/act12")
public String act12(Model model){
model.addAttribute("msg","act12");
return "forward:act11";
}
JSP页面:
<body>
${msg}
</body>
结果:
URL没有变化,数据存在可以直接使用。
三、文件上传
在Spring MVC中有两种实现上传文件的办法,第一种是Servlet3.0以下的版本通过commons-fileupload与commons-io完成的通用上传,第二种是Servlet3.0以上的版本的Spring内置标准上传,不需借助第3方组件。通用上传也兼容Servlet3.0以上的版本。
添加上传依赖包
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-client</artifactId>
<version>1.18.1</version>
</dependency>
新增上传页面
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>上传文件</title>
</head>
<body>
<h2>上传文件(支持多文件上传)</h2>
<form action="fileSave" method="post" enctype="multipart/form-data">
<p>
姓名:<input type="text" name="username"><br>
文件:
<input type="file" name="files" multiple="multiple" />
<%--<input type="file" name="files" multiple="multiple" />--%>
<%--<input type="file" name="files" multiple="multiple" />--%>
<p>
<button>提交</button>
</p>
<p>
${message}
</p>
</form>
</body></html>
如果有成功上传,页面中有几个关键点要注意:method的值必为post;enctype必须为multipart/form-data,该类型的编码格式专门用于二进制数据类型;上传表单元素必须拥有name属性;
修改配置文件,增加上传配置
默认情总下Spring MVC对文件上传的视图内容是不能解析的,要配置一个特别的解析器解析上传的内容,修改springmvc-servlet.xml配置文件,增加如下配置内容:
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="utf-8" />
<property name="maxUploadSize" value="10485760000" />
<property name="maxInMemorySize" value="40960" />
</bean>
增加了一个类型为CommonsMultipartResolver类型的解析器,各属性的意义:
defaultEncoding:默认编码格式
maxUploadSize:上传文件最大限制(字节byte)
maxInMemorySize:缓冲区大小
增加控制器与Action
@Controller
@RequestMapping("/up")
public class UpFileController {
@RequestMapping(value="/fileSave",method=RequestMethod.POST)
public String fileSave(Model model, @RequestParam MultipartFile[] files, HttpServletRequest request) throws Exception{
String username=request.getParameter("username");
System.out.println(username);
//文件存放的位置
String path=request.getServletContext().getRealPath("/files");
String fileName=null;
for (MultipartFile file : files) {
fileName=file.getOriginalFilename();
System.out.println(file.getOriginalFilename());
File tempFile=new File(path, file.getOriginalFilename());
if(!tempFile.exists()) {
tempFile.mkdirs();
}
//文件上传
file.transferTo(tempFile);
}
System.out.println(path);
model.addAttribute("path",path);
model.addAttribute("fileName",fileName);
return "upload";
}
测试运行