数据响应和结果视图
1. 返回字符串
Controller 方法返回字符串可以指定逻辑视图的名称,根据视图解析器为物理视图的地址
@RequestMapping(value="/hello")
public String sayHello() {
System.out.println("Hello SpringMVC!!!");
// 跳转到XX页面
return "success";
}
2. 返回 void
如果控制器的方法返回值是 void,执行程序报 404 异常(没有找到默认的 JSP 页面),我们可以使用请求转发或者重定向跳转到指定的页面
@RequestMapping(value="/initAdd")
public void initAdd(HttpServletRequest request,HttpServletResponse response) throws Exception {
System.out.println("请求转发或者重定向");
// 请求转发
request.getRequestDispatcher("/WEB-INF/pages/add.jsp").forward(request, response);
// 重定向
response.sendRedirect(request.getContextPath()+"/add2.jsp");
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
return;
}
3.返回 ModelAndView 对象
ModelAndView 是 SpringMVC 为我们提供的一个对象,该对象也可以用作控制器方法的返回值
/**
* 返回ModelAndView对象
* 可以传入视图的名称(即跳转的页面),还可以传入对象
* @return
* @throws Exception
*/
@RequestMapping(value="/findAll")
public ModelAndView findAll() throws Exception {
ModelAndView mv = new ModelAndView();
// 跳转到list.jsp的页面
mv.setViewName("list");
// 模拟从数据库中查询所有的用户信息
List<User> users = new ArrayList<>();
User user1 = new User();
user1.setUsername("张三");
user1.setPassword("123");
User user2 = new User();
user2.setUsername("李四");
user2.setPassword("456");
users.add(user1);
users.add(user2);
// 添加对象
mv.addObject("users", users);
return mv;
}
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!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>Insert title here</title>
</head>
<body>
<h3>查询所有的数据</h3>
<c:forEach items="${ users }" var="user">
${ user.username }
</c:forEach>
</body>
</html>
4. forward 请求转发和 redirect 重定向
- forward 请求转发
controller 方法在提供了 String 类型的返回值之后,默认就是请求转发。我们也可以写成:
@RequestMapping("/testForward")
public String testForward() {
System.out.println("AccountController 的 testForward 方法执行了。。。。");
return "forward:/WEB-INF/pages/success.jsp";
}
注意:
如果使用 formward,则路径必须写成实际视图 url,不能写逻辑视图
它相当 “request.getRequestDispatcher("url").forward(request,response)”
使用请求转发,既可以转发到 jsp,也可以转发到其他的控制器方法
- redirect 重定向
@RequestMapping("/testRedirect")
public String testRedirect() {
System.out.println("AccountController 的 testRedirect 方法执行了。。。。");
return "redirect:testReturnModelAndView";
}
注意:
它相当于 “response.sendRedirect(url)”
如果是重定向到 jsp 页面,则 jsp 页面不能写在 WEB-INF 目录中,否则无法找到
5. ResponseBody 注解响应 json 数据
@ResponseBody 注解实现将 controller 方法返回对象转换为指定格式的数据响应给客户端
DispatcherServlet 会拦截到所有的资源,导致静态资源(img、css、js)也会被拦截,从而不能被使用。因此,我们需要配置静态资源不进行拦截,在 springmvc.xml 配置文件添加如下配置:
<!-- 设置静态资源不过滤,mvc:resources 标签配置不过滤 -->
<mvc:resources location="/css/" mapping="/css/**"/> <!-- 样式 -->
<mvc:resources location="/images/" mapping="/images/**"/> <!-- 图片 -->
<mvc:resources location="/js/" mapping="/js/**"/> <!-- javascript -->
使用 @RequestBody 注解把 json 的字符串转换成 JavaBean 对象
@RequestMapping("/testJson")
public @ResponseBody Address testJson(@RequestBody Address address) {
System.out.println(address);
address.setAddressName("上海");
return address;
}
json 字符串和 JavaBean 对象互相转换的过程中,需要使用 jackson 的 jar 包
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.9.0</version>
</dependency>