目录
@RequestMapping注解
@PathVariable注解
Spring MVC支持REST风格的请求
请求处理方法签名
@RequestParam
除了可以修饰方法,还可以修饰类。
修饰类,提供初步的请求映射信息。相对于WEB应用的根目录。
修饰方法,提供进一步的细分映射信息。相对于类定义处的URL。若类定义处未标注该注解,则方法处标注的URL相对于WEB应用的根目录。
@RequestMapping除了可以使用请求URL映射请求外,还可以使用请求方法、请求参数及请求头映射请求。
@RequestMapping的value、method、params及heads分别表示请求URL、请求方法、请求参数及请求头的映射条件。他们之间是与的关系,联合使用多个条件可让请求映射更加精确化。
params和headers支持简单的表达式:
1. param1:表示请求必须包含名为param1的请求参数。
2. !param1:表示请求不能包含名为param1的请求参数。
3. param1 != value1:表示请求包含名为param1的请求参数,但其值不能为value1
4. {"param1=value1","param2"}:请求必须包含名为param1和param2的两个请求参数,且param1参数的值必须为value1
@RequrstMapping支持Ant风格的映射:
Ant风格资源地址支持3种匹配符:
1. ?:匹配文件名中的一个字符
2. *:匹配文件名中的任意字符
3. **:**匹配多层路径
例如:/usr/*/createUser 匹配/usr/aaa/createUser、/usr/bbb/createUser等
/usr/**/createUser 匹配/usr/createUser、/usr/aaa/bbb/createUser等
/usr/createUser?? 匹配/usr/createUseraa、/usr/createUserbb等
映射URL绑定的占位符到目标方法的参数中
带占位符的URL是spring 3.0新增的功能,该功能在spring mvc向REST目标挺进发展过程中具有里程碑的意义。
通过@PathVariable可以将URL中占位符参数绑定到控制器处理方法的入参中
URL中的{XXX}占位符可以通过@PathVariable("xxx")绑定到操作方法的入参中。
@RequestMapping("/delete/{id}")
public String delete(@Pathvariable("id") Integer id){
return "succ";
}
REST:即Representational State Transfer 。(资源)表现层状态转化。它结构清晰、符合标准、易于理解、扩展方便。
资源(Resources):
网络上的一个实体,或者说是网络上的一个具体信息。它可以是一段文本、一张图片、一首歌曲、一种服务,总之就是一个具体的存在。
可以用一个URL(统一资源定位符)指向它,每种资源对应一个特定的URL。
要获取这个资源,访问它的URL就可以。
因此URL即为每一个资源的独一无二的识别符。
表现层(Representation):
把资源具体呈现出来的形式,叫做它的表现层。
比如,文本可以用txt格式体现,也可以用HTML格式、XML格式、JSON格式表现,甚至可以采用二进制格式。
状态转化(State Transfer):
每发出一个请求,就代表了客户端和服务器的一次交互过程。
HTTP协议是一个无状态协议,即所有的状态都保存在服务器端。
因此,如果客户端想要操作服务器,必须通过某种手段,让服务器发生“状态转化”,而这种转化是建立在表现层之上的,所以就是“表现层状态转化”。
具体说,就是HTTP协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE,它们分别对应四种基本操作。GET用来获取资源,POST用来新建资源,PUT用来更新资源,DELETE用来删除资源。
例如:/order/1 HTTP GET 得到id=1的order
/order/1 HTTP DELETE 删除id=1的order
/order/1 HTTP PUT 更新id=1的order
/order HTTP POST 新增oder
HiddenHttpMethodFilter:
浏览器form表单只支持GET与POST请求,而DELETE、PUT等method并不支持,spring 3.0添加了一个过滤器,可以将这些请求转换为标准的http方法,使得支持GET、POST、PUT与DELETE请求。
HiddenHttpMethodFilter
org.springframework.web.filter.HiddenHttpMethodFilter
HiddenHttpMethodFilter
/*
jsp执行方法执行DELETE请求实例:
@RequestMapping(value="springmvc/test/{id}",method=RequestMethod.DELETE)
public String test(@PathVariable Integer id){
return "succ";
}
spring mvc通过分析处理方法的签名,将HTTP请求信息绑定到处理方法的相应入参中。
spring mvc对控制器处理方法签名的限制是很宽松的,几乎可以按喜欢的任何方式对方法进行签名。
必要时可以对方法及方法入参标注相应的注解(@PathVariable、@RequestParam、@RequestHeader等),spring mvc框架会将HTTP请求的信息绑定到相应的方法入参中,并根据方法的返回值类型做出相应的后续处理。
绑定请求参数值
在处理方法入参处使用@RequestParam可以把请求参数传递给请求方法。
value:参数名
required:是否必须。默认为true。表示请求参数中必须包含对应的参数,若不存在,将抛出异常。
@RequestMapping("test")
public String test(@RequestParam(value="userName",required=false) String userName,
@RequestParam("age") Integer age){
return "succ";
}
@RequestMapping("test")
public String test(@RequestParam(value="userName",required=false) String userName,
@RequestParam(value="age",required=false,defaultValue="0") int age){
return "succ";
}