简介
在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ,然后再把该Model 返回给对应的View 进行展示。
示例
不适用注解修饰
返回ModelAndView
controller方法中定义ModelAndView对象并返回,对象中可添加model数据、指定view。
package com.cyb.ssm.controller;
import java.util.ArrayList;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.stereotype.Service;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import com.cyb.ssm.po.Item;
import com.cyb.ssm.service.ItemService;
@Controller
public class ItemController {
@Autowired
private ItemService Service;
@RequestMapping("queryItem")
public ModelAndView queryItem() {
List<Item> itemList = Service.queryItemList();
ModelAndView mvAndView = new ModelAndView();
mvAndView.addObject("itemList", itemList);
mvAndView.setViewName("item/item-list");
return mvAndView;
}
}
返回void
方法形参上可以定义request和response,使用request或response指定响应结果:
void service(HttpServletRequest request,HttpServletResponse response){}
1、使用request转发向页面,如下:
request.getRequestDispatcher("页面路径").forward(request, response);
2、也可以通过response页面重定向:
response.sendRedirect("url")
3、也可以通过response指定响应结果,例如:
response.setCharacterEncoding("utf-8");
response.setContentType("application/json;charset=utf-8");
response.getWriter().write("json串");
返回字符串
public String queryItem(HttpServletRequest request,Model model) {
//查询数据库,用静态数据模拟
List<Item> itemList = Service.queryItemList();
//方式一,使用Request的API
// request.setAttribute("itemList", itemList);
//方式二,使用Model接口的API
model.addAttribute("itemList", itemList);
return "item/item-list";
}
逻辑视图名
return "item/item-list";
redirect重定向
return "redirect:testRedirect";
redirect:
相当于“response.sendRedirect()”
游览器URL发生改变
Request域不能共享
forward转发
return "forward:testForward";
forward:
相当于“request.getRequestDispatcher().forward(request,response)”
浏览器URL不发送改变
Request域可以共享
@RequestMapping("queryItem")
public String queryItem(HttpServletRequest request,Model model) {
//查询数据库,用静态数据模拟
List<Item> itemList = Service.queryItemList();
//方式一,使用Request的API
// request.setAttribute("itemList", itemList);
//方式二,使用Model接口的API
model.addAttribute("itemList", itemList);
// return "item/item-list";
//转发和重定向使用的代码
request.setAttribute("id", 1);
// return "redirect:testRedirect";
return "forward:testForward";
}
//请求重定向测试
@RequestMapping("testRedirect")
public String testRedirect(HttpServletRequest request){
String id = (String) request.getAttribute("id");
System.out.println("request域的id:"+id);
return "";
}
//请求转发测试
@RequestMapping("testForward")
public String testForward(HttpServletRequest request){
Integer id = (Integer) request.getAttribute("id");
System.out.println("request域的id:"+id);
return "";
}
使用注解修饰
返回带ResponseBody注解的值
@ResponseBody注解和@RequestBody注解介绍
@ResponseBody的作用:
ResponseBody注解可以通过内置9种HttpMessageConverter,匹配不同的Controller返回值类型,然后进行不同的消息转换处理
响应体返回到页面,
ContentType值也不同。
@RequestBody注解的作用和@ResponseBody注解正好相反,它是处理请求参数的Http消息转换的。
@RequestMapping("queryItemById")
public @ResponseBody Item queryItemById() {
Item item=Service.queryItemById(1);
return item;
}
// @RequestMapping("queryItemById")
// @ResponseBody
// public Item queryItemById2() {
// Item item=Service.queryItemById(1);
// return item;
// }
//@RestController相当于@Controller和@ResponseBody的组合
//该类所有方法的返回值都将被@ResponseBody注解给修饰
@RestController
public class RestItemController {
@Autowired
private ItemService Service;
@RequestMapping("queryItemByIdWithRest")
public Item queryItemById() {
Item item = Service.queryItemById(1);
return item;
}
}
常用的 HttpMessageConverter
MappingJacksonHttpMessageConverter处理POJO类型返回值
MappingJacksonHttpMessageConverter是专门处理POJO类型的。
默认使用MappingJackson的JSON处理能力,将后台返回的Java对象(POJO类型),转为JSON格式输出到页面。
将响应体的Content-Type设置为application/json;charset=utf-8
StringHttpMessageConverter处理String类型返回值
StringHttpMessageConverter是专门处理String类型的。
调用response.getWriter()方法将String类型的字符串写回给调用者。
将响应体的Content-Type设置为text/plain;charset=utf-8
@RequestMapping
通过RequestMapping注解可以定义不同的处理器映射规则
URL路径映射
value="/item")或@RequestMapping("/item")
value的值是数组,可以将多个url映射到同一个方法
"/item","/queryItem"})
窄化请求映射
class上添加@RequestMapping(url)指定通用请求前缀,限制此类下的所有方法的访问请求url必须以请求前缀开头,通过此方法对url进行模块化分类管理。
example
商品模块
item/add
item/update
item/delete
用户模块
user/add
user/update
user/delete
请求方法限定
限定GET方法
method=RequestMethod.GET)
如果通过Post访问则报错:
HTTP Status 405 - Request method 'POST' not supported
例如:
@RequestMapping(value="/editItem",mtthod=RequestMethod.GET)
限定POST方法
method=RequestMethod.POST)
如何通过Post访问则报错:
HTTP Status 405 - Request method 'GET' not supported
GET和POST都可以
@RequestMapping(mthod={RequestMethod.GET,RequestMethod.POST})
作者:陈彦斌