SpringMVC框架笔记整理(二): 注解式控制器-URL路径映射

注解式控制器

通过@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 的方法,可以从隐含对象中获取隐含的模型数据中获取对象,再将请求参数 –绑定到对象中,再传入入参将方法入参对象添加到模型中

  • @InitBinder
    自定义数据绑定注册支持,用于将请求参数转换到命令对象属性的对应类型

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配置文件中没有指定配置时使用的默认策略

SpringMVC框架笔记整理(二): 注解式控制器-URL路径映射_第1张图片

一个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。

URL路径映射

普通URL路径映射

@RequestMapping(value={“/test1”, “/user/create”}):多个URL路径可以映射到同一个处理器的功能处理方法,组合使用是或的关系,即“/test1”或“/user/create”请求URL路径都可以映射到@RequestMapping指定的功能处理方法。

URI模板模式映射

@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的支持;

你可能感兴趣的:(web开发框架,Java开发,Web开发,spring,mvc,框架)