基本介绍
@RequestMapping注解可以指定控制器/处理器的某个方法的请求的url,
示例 (结合springMVC基本原理理解)
@Controllerpublic class UserHandler {@RequestMapping(value = "/login")public String login() {System.out.println("登录了");return "/loginOK";}}
细节一、
@RequestMapping不仅可以修饰方法, 还可以修饰类
当同时修饰类和方法时,jsp请求的url 就是/类请求值/方法请求值
@Controller@RequestMapping(value ="user")public class UserHandler {@RequestMapping(value = "/login")public String login() {System.out.println("登录了");return "loginOK";}}
Title 登录
用户名:
密码:
登录:
细节二、
@RequestMapping还可以指定请求的方式(post/get/put/delete..)
@Controller@RequestMapping(value ="user")public class UserHandler {@RequestMapping(value = "/login", method = RequestMethod.GET)public String login() {System.out.println("登录了");return "loginOK";}}
相应地,前端form表单的请求方式也必须改为method = get
细节三、
@RequestMapping 还可以指定params和headers(了解)
(1)param1:表示请求必须包含名为param1的请求参数
(2)!=param1:表示请求不能包含名为param1的请求参数
(3)param1!=value1:表示请求包含名为param1的请求参数,但其值不能为value1
(4){“param1=value1”,“param2”}:请求必须包含名为param1和param2的两个请求参数,且param1参数的值必须为value1
示例
params属性指定请求的URL必须包含bookid
@RequestMapping (value="/test1", params="bookid")public String test1(){System. out.printIn("test1.……… ").return"ok";}
请求url中带一个名为bookid的参数
test1方法
细节四、
@RequestMaping 支持Ant风格资源地址(了解)
(1)?:匹配文件名中的一个字符
(2)*:匹配文件名中的任意字符
(3)**:**匹配多层路径
Ant风格的url地址举例
/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
@RequestlMapping(value="/test2/**"){public String test2()System. out.printIn("test2.……. ");return "ok";}
演示Ant风格的请求资源方式
发送消息1
发送消息2
细节五、
@RequestMapping 还可以配合@PathVariable 映射URL绑定的占位符。
test3方法PathVariable
//使用@PathVariable 映射URL 绑定的占位符,这样就不需要在url带上参数名了@RequestMapping(value="/test3/{name}/{id}")public String test3(@PathVariable("name") String name, @PathVariable("id") String id){{System.out.println("name = " + name + "--id--" + id);return "ok";}