通过@Controller 和 @RequestMapping注解定义我们的处理器类
spring2.5需要通过处理器映射DefaultAnnotationHandlerMapping和处理器适配器
AnnotationMethodHandlerAdapter
来开启支持@Controller 和@RequestMapping注解的处理器。
<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>
Spring3.1使用新的@Contoller和@RequestMapping注解支持类:
处理器映射RequestMappingHandlerMapping
和处理器适配器RequestMappingHandlerAdapter
<bean
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
<bean
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
Spring2.5+ 通过注解式处理器支持,通过@Controller和@RequestMapping注解定义处理器类。
@Controller
负责注册一个bean 到spring 上下文中, 用于标识是处理器类;
@RequestMapping
注解为控制器指定可以处理哪些 URL 请求
@RequestParam
在处理方法入参处使用 @RequestParam 可以把请求参 数传递给请求方法
@ModelAttribute
Spring MVC 在调用目标处理方法前,会先逐个调用在方法级上标注了- @ModelAttribute 的方法,可以从隐含对象中获取隐含的模型数据中获取对象,再将请求参数 –绑定到对象中,再传入入参将方法入参对象添加到模型中
RestFul架构风格注解
@RequestBody
该注解用于读取Request请求的body部分数据,使用系统默认配置的
HttpMessageConverter进行解析,
然后把相应的数据绑定到要返回的对象上 ,再把HttpMessageConverter返回的对象数据绑定到 controller中方法的参数上
@ResponseBody
该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区
@PathVariable
绑定 URL 占位符到入参, 请求URI中的模板变量部分到处理器功能处理方法的方法参数上的绑定
@ExceptionHandler
注解到方法上,出现异常时会执行该方法
@ControllerAdvice
使一个Contoller成为全局的异常处理类,类中用@ExceptionHandler方法注解的方法可以处理所有Controller发生的异常
<mvc:annotation-driven>
<mvc:interceptors>
<mvc:interceptors>
<bean class="com.cpsh.inteceptor.mvc.MyInteceptor01" />
<mvc:interceptor>
<mvc:mapping path="/hello/*" />
<bean class="com.cpsh.inteceptor.mvc.MyInteceptor02"/>
mvc:interceptor>
mvc:interceptors>
<mvc:resources>
<mvc:resources mapping="/res/images/**" location="/common/images/" cache-period="31556926" />
DispatcherServlet的默认配置在DispatcherServlet.properties(和DispatcherServlet类在一个包下)中,而且是当Spring配置文件中没有指定配置时使用的默认策略
一个POJO类上放置@Controller或@RequestMapping,即可把一个POJO类变身为处理器; @RequestMapping(value = “/hello”) 请求URL(/hello) 到 处理器的功能处理方法的映射;
/**
url = "${contextPath}/user/hello2"
*/
package cn.javass.chapter6.web.controller;
@Controller
@RequestMapping(value="/user") //①处理器的通用映射前缀
public class HelloWorldController2 {
@RequestMapping(value = "/hello2") //②相对于①处的映射进行窄化
public ModelAndView helloWorld() {
//省略实现
}
}
请求映射可以认为是方法级别的@RequestMapping继承类级别的@RequestMapping。
@RequestMapping(value={“/test1”, “/user/create”}):多个URL路径可以映射到同一个处理器的功能处理方法,组合使用是或的关系,即“/test1”或“/user/create”请求URL路径都可以映射到@RequestMapping指定的功能处理方法。
@RequestMapping(value=”/users/{userId}”):{×××}占位符, 请求的URL可以是 “/users/123456”, 通过@PathVariable可以提取URI模板模式中的{×××}中的×××变量。
@RequestMapping(value=”/users/{userId}/topics/{topicId}”)
@RequestMapping(value=”/products/{categoryCode:\d+}-{pageNumber:\d+}”):可以匹配“/products/123-1, 通过@PathVariable提取模式中的{×××:正则表达式匹配的值}中的×××变量
正则表达式风格的URL路径映射是一种特殊的URI模板模式映射:
URI模板模式映射是{userId},不能指定模板变量的数据类型,如是数字还是字符串;
正则表达式风格的URL路径映射,可以指定模板变量的数据类型,可以将规则写的相当复杂
@RequestMapping(value=”/methodOr”, method = {RequestMethod.POST, RequestMethod.GET}):即请求方法可以是 GET 或 POST。
DispatcherServlet默认开启对 GET、POST、PUT、DELETE、HEAD的支持;