RestFul和控制器
控制器:
- 控制器负责提供访问应用程序的行为,通常通过接口定义或者注解定义两种方式
- 控制器负责解析用户的请求并将其转换为一个模型
- 在SpringMVC中一个控制器类可以包含多个方法
- 在SpringMVC中,对Controller的配置方法有很多种
实现Controller接口
Controller接口源码:
@FunctionalInterface
public interface Controller {
@Nullable
ModelAndView handleRequest(HttpServletRequest var1, HttpServletResponse var2) throws Exception;
}
编写一个Controller的实现类:
//注意不要导错包
public class ControllerTest1 implements Controller {
public ModelAndView handleRequest(javax.servlet.http.HttpServletRequest httpServletRequest, javax.servlet.http.HttpServletResponse httpServletResponse) throws Exception {
//返回一个模型视图对象
ModelAndView mv=new ModelAndView();
mv.addObject("msg","Test1Controoler");
mv.setViewName("test");
return mv;
}
}
在Spring配置文件中注册请求Bean;name对应请求路径,class对应请求处理类
<bean name="/t1" class="com.ssm.controller.ControllerTest1"></bean>
编写前端页面,注意是在目录WEB-INF/jsp/下
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
${msg}
</body>
</html>
测试:
注意:
- 实现接口的方式比较老
- 缺点:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;比较麻烦
使用注解@Controller
-
@Controller注解类型用于声明Spring类的实例的一个控制器
-
Spring能通过扫描机制来找到应用程序中所有的基于注解的控制器类,为了保证Spring能找到控制器,需要配置文件中声明组件扫描
<context:component-scan base-package="com.ssm"/>
-
测试:增加一个ControllerTest2的实现类,使用注解实现
@Controller注解的类会自动添加到Spring上下文中 @Controller public class ControllerTest2 { @RequestMapping("/t2") public String index(Model model){ //Spring MVC会自动实例化一个Model对象用于向视图中传值 model.addAttribute("msg","ControllerTest2"); //返回视图位置 return "test"; } }
测试:
**注意:**两个请求都指向了一个视图,但结果却不一样,证明:视图被复用了,而控制器和视图之间是弱耦合关系
RestFul风格
一个资源定位及资源操作的风格,只是一种风格,让软件的设计更加简洁,更有层次,更容易实现缓存的那个机制
测试:
- 新建一个类RestFulController
@Controller
public class RestFulController {
}
- 在Spring MVC中可以使用 @PathVariable 注解,让方法参数的值对应绑定到一个URI模板变量上。
@Controller
public class RestFulController {
//映射访问路径
@RequestMapping("/commit/{p1}/{p2}")
public String index(@PathVariable int p1,@PathVariable int p2, Model model){
int result=p1+p2;
//Spring MVC会自动实例化一个Model对象用于向视图中传值
model.addAttribute("msg","结果:"+result);
//返回视图位置
return "test";
}
}
测试:
风格好处:
- 使路径更加简洁
- 获得参数更加方便,框架会自动转换
- 通过路径变量可以约束访问参数,如果类型不一致,则访问不到对应的请求方法
使用method属性指定请求类型
用于约束请求的类型,可以收窄请求范围。指定请求谓词的类型如GET, POST, HEAD, OPTIONS, PUT, PATCH, DELETE, TRACE等
测试:
新增一个方法:
映射访问路径,必须是POST请求
@RequestMapping(value = "/hellocoffic}",method = RequestMethod.POST)
public String index2( Model model){
//Spring MVC会自动实例化一个Model对象用于向视图中传值
model.addAttribute("msg","HELLOCOFFIC");
//返回视图位置
return "test";
}
使用GET请求方式访问就会报405:
总结:
-
Spring MVC 的 @RequestMapping 注解能够处理 HTTP 请求的方法, 比如 GET, PUT, POST, DELETE 以及 PATCH。
-
所有地址默认请求是GET
-
除了@RequestMapping 还有几个注解变体:
@GetMapping @PostMapping @PutMapping @DeleteMapping @PatchMapping
比如 GET, PUT, POST, DELETE 以及 PATCH。
-
所有地址默认请求是GET
-
除了@RequestMapping 还有几个注解变体:
@GetMapping @PostMapping @PutMapping @DeleteMapping @PatchMapping