SpringMVC入门(二)--使用@RequestMapping映射请求
2016-06-14 14:29
288 查看
SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些URL的请求
在控制器的类定义及方法定义处都可以标注
1. 类定义处:提供初步的请求 信息,相对于WEB应用的根路径
2. 方法定义处:提供进一步的细分映射信息,相对于类定义处的URL,若类定义处没有标注@RequestMapping,则方法标记相对于WEB的根路径
DispatcherServlet在截获请求后就通过控制器上@RequestMapping提供映射信息确定请求所对应的处理
基本的@RequestMapping的使用
在处理器(Controller)中使用了@RequestMapping(url),则在访问此方法的时候 就调用此url
在处理器中也加入了@RequestMapping(url),在使用url访问的时候 就不要先将类中的url+方法上的url
3.其中@RequestMapping的value,method,params及heads分别表示请求URL,请求方法,请求参数及请求头的映射条件,他们是与的关系,联合使用多个条件可让请求映射更加精确
3.1@RequestMapping中的method,通过method限制提交请求的方法
params1:表示请求必须包含名为param1的请求参数
!params1:表示请求不能包含名为param1的请求参数
param1!=value1:表示请求包含名为param1的请求参数,但其值不能为value1
{“param1=value1”,{“param2”}}:请求必须包含名为param1和param2的两个请求参数,且param1参数的值必须为value1
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
后续继续………
在控制器的类定义及方法定义处都可以标注
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
后续继续………
相关文章推荐
- Spring整合Dwr,Cannot locate BeanDefinitionParser for element [annotation-scan]
- spring3 MVC手工搭建Spring3项目demo
- spring mvc 开发需要的jar包的用途详解
- 基于注解的 Spring MVC 简单入门-网摘
- [MVC] 深入浅出Spring MVC
- spring mvc的web.xml的配置
- SpringMVC工作原理
- Spring MVC静态资源处理<mvc:resources><mvc:default-servlet-handler>
- Spring MVC 为例,从前台—>后台—>前台的编解码过程及出现乱码的案例
- 在spring mvc与mybatis中加入logback
- springmvc+mybatis
- 当项目使用SpringMvc时拦截器的注意事项
- (struts2) spring mvc + mybatis + maven整合
- 文章标题
- Spring+Spring MVC 整合JasperReports
- 使用springmvc框架之第1篇:spring中bean的系统自动注册
- SpringMVC Json
- ajax跨域:JQuery + Spring MVC3.0
- 项目经验之springmvc单元测试
- spring mvc详解1