(一)配置Controller的方式
参考:Spring MVC官方文档
1.注解配置Controller类最为常用
1.Controller注解类型
@Controller注解一个java控制类不需要再实现jController接口,并且注解后的控制类可以通过Spring扫描机制可以找到
标注@Controller的控制类。
HelloWeb-servlet.xml配置文件添加以下元素:
<!--扫描com.wamg包下的所有类的注解-->
<context:component-scan base-package="com.wang" />
2.@RequestMapping注解的使用
@RequestMapping(value="/hello")等价@RequestMapping("/hello")
方式一:标注在类上时,该类所有的方法请求都将映射为相对于类级别的请求,
表示该控制器所处理的所有请求都被映射到value属性所指定的路径。
方式二:标注在一个方法上意思直接请求控制类的这个方法来处理。
3.组合注解:简化代码
传统方式: @RequestMapping(value="/hello1", method = RequestMethod.GET)
组合注解:@GetMapping(value="/hello1")这样就少写了 method = RequestMethod.GET
4.组合注解类型
注解 | 说明 |
---|---|
@GetMapping | 匹配Get方式的请求 |
@PostMapping | 匹配Post方式的请求 |
@PutMapping | 匹配Put方式的请求 |
@DeleteMapping | 匹配Delete方式的请求 |
@PatchMapping | 匹配Patch方式的请求 |
5.处理结果返回类型
1.redirect重定向
//请求映射一下方法
@RequestMapping(value="/hello1", method = RequestMethod.GET)
//将数据显示在前端页面使用ModelMap类,该类不需要配置试图解析器
public String printHello(ModelMap model) {
//在model中设值数据以便前端页面使用EL表达式获取数据
model.addAttribute("message", "Hello Spring MVC Framework!");
//默认跳转方式为:转发
return "redirect:hello";
}
----------
2.forward请求转发
//请求映射一下方法
@RequestMapping(value="/hello1", method = RequestMethod.GET)
//将数据显示在前端页面使用ModelMap类,该类不需要配置试图解析器
public String printHello(ModelMap model) {
//在model中设值数据以便前端页面使用EL表达式获取数据
model.addAttribute("message", "Hello Spring MVC Framework!");
//默认跳转方式为:转发,可以不写forward
return "forward:hello";
}
HelloController.java
package com.wang;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.ui.ModelMap;
//使用@Controller声明Hello