一直在使用,这次系统的学习一下:
一、@RequstMapping映射
SpringMVC使用@RequestMapping注解为控制器指定可以处理的URL请求,在控制器的类定义及方法定义处都可以标注。
类定义处:定义初步的请求映射信息,相对于web应用的根目录;
方法定义处:提供进一步的细分映射映射信息。相对于类定义的URL。如果类定义处未标注@RequestMapping,则方法处标记的URL相对于web端应用的根目录。
DispatcherServlet截获请求之后,就通过控制器上@RequestMapping提供的映射信息确认请求对应的处理方法。
映射器请求的参数、请求方法或请求头
@RequestMapping除了可以使用请求url映射请求外,还可以使用请求方法,请求参数及其请求头映射请求;
@RequestMpping的value、method、param、heads分别表示请求url、请求方法、请求参数及其请求头的映射条件,他们之间是与的关系,联合使用多个参数条件可以让映射更加精准化。
params和headers支持简单的表达式:
例如:1、param1表示请求必须包含有param1的请求参数;
2、!param1表示请求不能包含名为param1的请求参数;
3、param1!=values1表示请求包含名为param1的请求参数,但是其值不能为value1;
4、{"param1=value1","param2"}:请求必须包含名为param1和param2的两个请求参数,且param1参数的值必须为value1;
@RequestMapping方法的映射请求:
Ant风格资源地址支持三种匹配符:
1、?:匹配文件名中的一个字符;
2、*:匹配文件命中的任意字符;
3、**:匹配多层路径;
@RequestMapping还支持Ant风格的url
1、/user/*/createUser:匹配user/aaa/createUser、user/bbb/createUser等url;
2、/user/**/createUser:匹配/user/createUser、/user/aaa/bbb/createUser等url;
3、/user/createUser??:匹配/user/createUseraa、/user/createUserbb等url;
二、@PathVariable映射URL绑定的占位符
带有占位符的url是Spring3.0新增的功能,该功能在SpingMVC像REST目标挺进发展过程中具有里程碑式的意义;
通过@PathVariable可以将url中占位符参数绑定到控制处理方法的入参中:url中的(xxx)占位符可以通过@PathVariable("xxx")绑定到操作方法的入参中。
@RequestMapping("/testPathVariable/{id}")
public String testPathVariable(@PathVariable("id") Integer id){
System.out.println("testPathVariable: " + id);
return "SUCCESS";
}
三、使用@RequestHeader绑定请求报头的属性值
请求头包含了若干个属性,服务器可以据此获知客户端的信息,通过@RequestHeader即可将请求头中的属性值绑定到处理方法的入参中。
private static final String SUCCESS="success";
@RequestMapping("/testRequestHeader")
public String testRequestHeader(@RequestHeader(value="Accept-Lanager") String al){
System.out.println("testRequestHeader Accept-Lanager:"+al);
return SUCCESS;
}
四、使用@CookieValue绑定请求中Cookie的值
@CookieValue可以让处理方法入参绑定某个Cookie的值
private static final String SUCCESS="success";
@RequestMapping("/testCookieValue")
public String testCookieValue(@CookieValue("JESSIONID") String sessionId){
System.out.println("testCookieValue sessionId="+sessionId);
return SUCCESS;
}