SpringMVC笔记03 常用注解
coconutnut

https://www.bilibili.com/video/BV1Sb411s7qa

P17~24

RequestParam

作用:把请求中的指定名称的参数传递给控制器中的形参赋值

属性:

  • value:请求参数中的名称
  • required:请求参数中是否必须提供此参数,默认值是true,必须提供

如,方法中需要name属性,但是url中传的是username属性,就会封装不上

可以用@RequestParam修饰参数

1
2
3
4
5
@RequestMapping(path="/hello")
public String sayHello(@RequestParam(value="username",required=false)String name) {
System.out.println(name);
return "success";
}

RequestBody

作用:用于获取请求体的内容(get方法不适用)

直接使用得到的是key=value&key=value结构的数据

属性:

  • required:是否必须有请求体,默认值是true
1
2
3
4
5
<form action="anno/testRequestBody" method="post">
用户姓名:<input type="text" name="username" /><br/>
用户年龄:<input type="text" name="age" /><br/>
<input type="submit" value="提交" />
</form>
1
2
3
4
5
@RequestMapping(path="/testRequestBody")
public String sayHello(@RequestBody String body) {
System.out.println(body);
return "success";
}

后面传json数据时会用到

PathVariable

作用:用于绑定 url 中的占位符(如:请求 /delete/{id}中的{id})

用于支持RESTful风格

属性:

  • value:用于指定 url 中占位符名称
  • required:是否必须提供占位符
1
<a href="springmvc/usePathVariable/100">pathVariable 注解</a>
1
2
3
4
5
@RequestMapping("/usePathVariable/{id}")
public String usePathVariable(@PathVariable("id") Integer id){
System.out.println(id);
return "success";
}

用RESTful风格时

由于浏览器form表单只支持GET与POST请求,而不支持DELETE、PUT

Spring3.0提供了一个过滤器HiddentHttpMethodFilter,可以将浏览器请求修改为指定方式,但比较麻烦

还有WebClient类可以使用静态方法模拟各种请求方式

或者可以给浏览器装插件

RequestHeader

作用:获取请求消息头

属性:

  • value:提供消息头名称
  • required:是否必须有此消息头
1
2
3
4
5
6
@RequestMapping("/useRequestHeader")
public String useRequestHeader(@RequestHeader(value="Accept-Language",
required=false)String requestHeader){
System.out.println(requestHeader);
return "success";
}

CookieValue

作用:获取Cookie的值

属性:

  • value:指定 cookie 的名称
  • required:是否必须
1
2
3
4
5
@RequestMapping("/useCookieValue")
public String useCookieValue(@CookieValue(value="JSESSIONID",required=false) String cookieValue){
System.out.println(cookieValue);
return "success";
}

ModelAttribute

作用:加在方法上,该方法在控制器的方法执行前先执行;加在参数上,获取指定的数据给参数赋值

属性:

  • value:用于获取数据的 key(key 可以是 POJO 的属性名称,也可以是 map 结构的 key)

应用场景:

表单提交数据不完整时,先从数据库查用户信息,没有提交数据的字段用原值

1
2
3
4
5
<!-- 修改用户信息 -->
<form action="springmvc/updateUser" method="post">
用户名称:<input type="text" name="username" ><br/>
用户年龄:<input type="text" name="age" ><br/>
<input type="submit" value="保存"> </form>

ModelAttribute 修饰方法带返回值

1
2
3
4
5
6
7
8
9
10
11
12
13
@ModelAttribute
public User showModel(String username) {
//模拟去数据库查询
User abc = findUserByName(username);
System.out.println("执行了 showModel 方法"+abc);
return abc;
}

@RequestMapping("/updateUser")
public String testModelAttribute(User user) {
System.out.println("控制器中处理请求的方法:修改用户:"+user);
return "success";
}

ModelAttribute 修饰方法不带返回值

放到map中

1
2
3
4
5
6
7
8
9
10
11
12
13
@ModelAttribute
public void showModel(String username,Map<String,User> map) {
//模拟去数据库查询
User user = findUserByName(username);
System.out.println("执行了 showModel 方法"+user);
map.put("abc",user);
}

@RequestMapping("/updateUser")
public String testModelAttribute(@ModelAttribute("abc")User user) {
System.out.println("控制器中处理请求的方法:修改用户:"+user);
return "success";
}

SessionAttribute

作用:多次执行控制器方法间的参数共享

属性:

  • value:指定存入的属性名称
  • type:指定存入的数据类型
1
2
3
4
<!-- SessionAttribute 注解的使用 -->
<a href="springmvc/testPut">存入SessionAttribute</a> <hr/>
<a href="springmvc/testGet">取出SessionAttribute</a> <hr/>
<a href="springmvc/testClean">清除SessionAttribute</a>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
@Controller("sessionAttributeController")
@RequestMapping("/springmvc")
@SessionAttributes(value ={"username","password"},types={Integer.class}) public class SessionAttributeController {

@RequestMapping("/testPut")
public String testPut(Model model){
model.addAttribute("username", "泰斯特");
model.addAttribute("password","123456");
return "success";
}

@RequestMapping("/testGet")
public String testGet(ModelMap model){
System.out.println(model.get("username")+";"+model.get("password"));
return "success";
}

@RequestMapping("/testClean")
public String complete(SessionStatus sessionStatus){
sessionStatus.setComplete();
return "success";
}

}