SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些URL的请求
在控制器的类定义及方法定义处都可以标注
1. 类定义处:提供初步的请求 信息,相对于WEB应用的根路径
2. 方法定义处:提供进一步的细分映射信息,相对于类定义处的URL,若类定义处没有标注@RequestMapping,则方法标记相对于WEB的根路径
DispatcherServlet在截获请求后就通过控制器上@RequestMapping提供映射信息确定请求所对应的处理
- 基本的@RequestMapping的使用
在处理器(Controller)中使用了@RequestMapping(url),则在访问此方法的时候 就调用此url
@Controller
public class HelloWorldHander {
@RequestMapping("/hello")
public String hello(){
return "success";
}
}
//jsp部分
<a href="hello">hello world</a>
- 在处理器中也加入了@RequestMapping(url),在使用url访问的时候 就不要先将类中的url+方法上的url
@Controller
@RequestMapping("/spring")
public class SpringMVCTest {
public static final String SUCCESS="success";
@RequestMapping("/testTowRequestMapping")
public String testTowRequestMapping(){
System.out.println("testTowRequestMapping");
return SUCCESS;
}
}
//jsp部分
<a href="spring/testTowRequestMapping">SpringMVCTest</a>
3.其中@RequestMapping的value,method,params及heads分别表示请求URL,请求方法,请求参数及请求头的映射条件,他们是与的关系,联合使用多个条件可让请求映射更加精确
3.1@RequestMapping中的method,通过method限制提交请求的方法
/**
* 1.value 请求的URl
* 2.method:限定此方法响应的请求方法是post
*/
@RequestMapping(value="/testMethod",method=RequestMethod.POST)
public String testMethod(){
System.out.println("testMethod");
return SUCCESS;
}
//jsp部分
<form action="spring/testMethod" method="post">
<input type="submit" value="submit"/>
</form>
<br><br>
<a href="spring/testMethod">testMethod</a>
3.2@RequestMapping中的params和heads
params1:表示请求必须包含名为param1的请求参数
!params1:表示请求不能包含名为param1的请求参数
param1!=value1:表示请求包含名为param1的请求参数,但其值不能为value1
{“param1=value1”,{“param2”}}:请求必须包含名为param1和param2的两个请求参数,且param1参数的值必须为value1
/**
* 1.参数必须包含username,age,但是age不能等于10,headers中的Accept-Language必须等于zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.8
* @return
*/
@RequestMapping(value="/testParamsAndheaders" ,params={"username","age!=10"},headers={"Accept-Language=zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.8"})
public String testParamsAndheaders(){
System.out.println("testParamsAndheaders");
return SUCCESS;
}
//jsp部分
<a href="spring/testParamsAndheaders?username=yyt&age=10">testParamsAndheaders</a>
4.Ant风格资源地址
在请求的url上面支持Ant风格的资源地址
规则如下:
?:匹配文件名中的一个字符
*:匹配文件名中的任意字符
:匹配多层路径
例子:
/user/*/createUser: 匹配/user/aaa/createUser、/user/bbb/createUser 等URL
/user/**/createUser: 匹配/user/createUser、/user/aaa/bbb/createUser 等URL
/user/createUser??: 匹 配/user/createUseraa、/user/createUserbb 等URL
后续继续………