基本介绍

@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";}