Spring2.5引入注解式处理器支持,经过@Controller 和 @RequestMapping注解定义咱们的处理器类。
而且提供了一组强大的注解:
须要经过处理器映射DefaultAnnotationHandlerMapping和处理器适配器
AnnotationMethodHandlerAdapter来开启支持@Controller 和 @RequestMapping注解的处理器。
@Controller:用于标识是处理器类;
@RequestMapping:请求处处理器功能方法的映射规则;
@RequestParam:请求参数处处理器功能处理方法的方法参数上的绑定;
@ModelAttribute:请求参数到命令对象的绑定;
@SessionAttributes:用于声明session级别存储的属性,放置在处理器类上,一般列出
模型属性(如@ModelAttribute)对应的名称,则这些属性会透明的保存到session中;
@InitBinder:自定义数据绑定注册支持,用于将请求参数转换到命令对象属性的对应类型;java
Spring3.0引入RESTful架构风格支持(经过@PathVariable注解和一些其余特性支持),且又引入了
更多的注解支持:
@CookieValue:cookie数据处处理器功能处理方法的方法参数上的绑定;
@RequestHeader:请求头(header)数据处处理器功能处理方法的方法参数上的绑定;
@RequestBody:请求的body体的绑定(经过HttpMessageConverter进行类型转换);
@ResponseBody:处理器功能处理方法的返回值做为响应体(经过HttpMessageConverter进行类型转换);
@ResponseStatus:定义处理器功能处理方法/异常处理器返回的状态码和缘由;
@ExceptionHandler:注解式声明异常处理器;
@PathVariable:请求URI中的模板变量部分处处理器功能处理方法的方法参数上的绑定,
从而支持RESTful架构风格的URI;web
Spring3.1使用新的HandlerMapping 和 HandlerAdapter来支持@Contoller和@RequestMapping注解处理器。
新的@Contoller和@RequestMapping注解支持类:处理器映射RequestMappingHandlerMapping和处理器适配器RequestMappingHandlerAdapter组合来代替Spring2.5开始的处理器映射
DefaultAnnotationHandlerMapping和处理器适配器AnnotationMethodHandlerAdapter,提供更多的扩展点。正则表达式
@Controller // 或 @RequestMapping //将一个POJO类声明为处理器 public class HelloWorldController { @RequestMapping(value = "/hello") //请求URL处处理器功能处理方法的映射 public ModelAndView helloWorld() { //一、收集参数 //二、绑定参数到命令对象 //三、调用业务对象 //四、选择下一个页面 ModelAndView mv = new ModelAndView(); //添加模型数据 能够是任意的POJO对象 mv.addObject("message", "Hello World!"); //设置逻辑视图名,视图解析器会根据该名字解析到具体的视图页面 mv.setViewName("hello"); return mv; //模型数据和逻辑视图名 } }
http请求信息包含六部分信息:
①请求方法,如GET或POST,表示提交的方式;
②URL,请求的地址信息;
③协议及版本;
④请求头信息(包括Cookie信息);
⑤回车换行(CRLF);
⑥请求内容区(即请求的内容或数据),如表单提交时的参数数据、URL请求参数(?abc=123 ?后边的)等。json
处理器的功能处理方法的映射,所以请求的映射分为以下几种:
URL路径映射:使用URL映射请求处处理器的功能处理方法;
请求方法映射限定:如限定功能处理方法只处理GET请求;
请求参数映射限定:如限定只处理包含“abc”请求参数的请求;
请求头映射限定:如限定只处理“Accept=application/json”的请求。cookie
普通URL路径映射
@RequestMapping(value={"/test1", "/user/create"}):多个URL路径能够映射到同一个处理器的功能处理方法。
URI模板模式映射
@RequestMapping(value="/users/{userId}"):{×××}占位符, 请求的URL能够是 “/users/123456”或“/users/abcd”,经过@PathVariable能够提取URI模板模式中的{×××}中的×××变量。
@RequestMapping(value="/users/{userId}/create"):这样也是能够的,请求的URL能够是“/users/123/create”。
@RequestMapping(value="/users/{userId}/topics/{topicId}"):这样也是能够的,请求的URL能够是“/users/123/topics/123”。
Ant风格的URL路径映射
@RequestMapping(value="/users/**"):能够匹配“/users/abc/abc”,但“/users/123”将会被【URI模板模式映射中的“/users/{userId}”模式优先映射到】@RequestMapping(value="/product?"):可匹配“/product1”或“/producta”,但不匹配“/product”或“/productaa”;
@RequestMapping(value="/product*"):可匹配“/productabc”或“/product”,但不匹配“/productabc/abc”;
@RequestMapping(value="/product/*"):可匹配“/product/abc”,但不匹配“/productabc”;
@RequestMapping(value="/products/**/{productId}"):可匹配“/products/abc/abc/123”或“/products/123”,也就是Ant风格和URI模板变量风格可混用;session
正则表达式风格的URL路径映射
从Spring3.0开始支持正则表达式风格的URL路径映射,格式为{变量名:正则表达式},经过@PathVariable提取模式中的{×××:正则表达式匹配的值}中的×××变量了。
@RequestMapping(value="/products/{categoryCode:\\d+}-{pageNumber:\\d+}"):能够匹配“/products/123-1”,但不能匹配“/products/abc-1”,这样能够设计更加严格的规则。
正则表达式风格的URL路径映射是一种特殊的URI模板模式映射:
URI模板模式映射是{userId},不能指定模板变量的数据类型,如是数字仍是字符串;
正则表达式风格的URL路径映射,能够指定模板变量的数据类型,能够将规则写的至关复杂。架构
组合使用是“或”的关系
如 @RequestMapping(value={"/test1", "/user/create"}) 组合使用是或的关系,即“/test1”或“/user/create”请求URL路径均可以映射到@RequestMapping指定的功能处理方法。
以上URL映射的测试类为:cn.javass.chapter6.web.controller.mapping.MappingController.java。
Spring WebMVC不单单提供URL路径映射,还提供了其余强大的映射规则。app