`

注解式控制器详解(注解式控制器运行流程及处理器定义)

阅读更多

 注解式控制器详解(注解式控制器运行流程及处理器定义)

 

注解式控制器简介

一、Spring2.5之前,我们都是通过实现Controller接口或其实现来定义我们的处理器类。已经@Deprecated。

 

二、Spring2.5引入注解式处理器支持,通过@Controller 和 @RequestMapping注解定义我们的处理器类。并且提供了一组强大的注解:

 

需要通过处理器映射DefaultAnnotationHandlerMapping和处理器适配器AnnotationMethodHandlerAdapter来开启支持@Controller 和 @RequestMapping注解的处理器。

 

@Controller:用于标识是处理器类;

@RequestMapping:请求到处理器功能方法的映射规则;

@RequestParam:请求参数到处理器功能处理方法的方法参数上的绑定;

@ModelAttribute:请求参数到命令对象的绑定;

@SessionAttributes:用于声明session级别存储的属性,放置在处理器类上,通常列出模型属性(如@ModelAttribute)对应的名称,则这些属性会透明的保存到session中;

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

 

三、Spring3.0引入RESTful架构风格支持(通过@PathVariable注解和一些其他特性支持),且又引入了更多的注解支持:

@CookieValue:cookie数据到处理器功能处理方法的方法参数上的绑定;

@RequestHeader:请求头(header)数据到处理器功能处理方法的方法参数上的绑定;

@RequestBody:请求的body体的绑定(通过HttpMessageConverter进行类型转换);

@ResponseBody:处理器功能处理方法的返回值作为响应体(通过HttpMessageConverter进行类型转换);

@ResponseStatus:定义处理器功能处理方法/异常处理器返回的状态码和原因;

@ExceptionHandler:注解式声明异常处理器;

@PathVariable:请求URI中的模板变量部分到处理器功能处理方法的方法参数上的绑定,从而支持RESTful架构风格的URI;

 

四、Spring3.1使用新的HandlerMapping 和 HandlerAdapter来支持@Contoller和@RequestMapping注解处理器。

新的@Contoller和@RequestMapping注解支持类:处理器映射RequestMappingHandlerMapping 和 处理器适配器RequestMappingHandlerAdapter组合来代替Spring2.5开始的处理器映射DefaultAnnotationHandlerMapping和处理器适配器AnnotationMethodHandlerAdapter,提供更多的扩展点。

 

接下来,我们一起开始学习基于注解的控制器吧。

6.2、入门

(1、控制器实现

 
  1. package cn.javass.chapter6.web.controller;  

  2. //省略import  

  3. @Controller         // 或 @RequestMapping               //①将一个POJO类声明为处理器  

  4. public class HelloWorldController {  

  5.    @RequestMapping(value = "/hello")                  //②请求URL到处理器功能处理方法的映射 

  6.    public ModelAndView helloWorld() {  

  7.        //1、收集参数  

  8.        //2、绑定参数到命令对象  

  9.        //3、调用业务对象  

  10.        //4、选择下一个页面  

  11.        ModelAndView mv = new ModelAndView();  

  12.        //添加模型数据 可以是任意的POJO对象  

  13.        mv.addObject("message""Hello World!");  

  14.        //设置逻辑视图名,视图解析器会根据该名字解析到具体的视图页面  

  15.        mv.setViewName("hello");  

  16.        return mv;                                         //○3 模型数据和逻辑视图名  

  17.    }  

  18. }  

 

1 可以通过在一个POJO类上放置@Controller或@RequestMapping,即可把一个POJO类变身为处理器;

@RequestMapping(value = "/hello") 请求URL(/hello) 到 处理器的功能处理方法的映射;

3 模型数据和逻辑视图名的返回。

 

现在的处理器无需实现/继承任何接口/类,只需要在相应的类/方法上放置相应的注解说明下即可,非常方便。

 

(2、Spring配置文件chapter6-servlet.xml

(2.1、HandlerMapping和HandlerAdapter的配置

如果您使用的是Spring3.1之前版本,开启注解式处理器支持的配置为:DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter。

 
  1. <!—Spring3.1之前的注解 HandlerMapping -->  

  2. <bean  

  3. class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"/>  

  4.  

  5. <!—Spring3.1之前的注解 HandlerAdapter -->  

  6. <bean  

  7. class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>  

  8.      

 

如果您使用的Spring3.1开始的版本,建议使用RequestMappingHandlerMapping和RequestMappingHandlerAdapter。

 
  1. <!--Spring3.1开始的注解 HandlerMapping -->  

  2. <bean  

  3. class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>  

  4. <!--Spring3.1开始的注解 HandlerAdapter -->  

  5. <bean  

  6. class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>  

下一章我们介绍DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter 与RequestMappingHandlerMapping和RequestMappingHandlerAdapter 的区别。

 

(2.2、视图解析器的配置

还是使用之前的org.springframework.web.servlet.view.InternalResourceViewResolver。

(2.3、处理器的配置

 
  1. <!-- 处理器 -->  

  2. <bean class="cn.javass.chapter6.web.controller.HelloWorldController"/>  

 

只需要将处理器实现类注册到spring配置文件即可,spring的DefaultAnnotationHandlerMapping或RequestMappingHandlerMapping能根据注解@Controller或@RequestMapping自动发现。

 

(2.3、视图页面(/WEB-INF/jsp/hello.jsp)

 
  1. <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>  

  2. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">  

  3. <html>  

  4. <head>  

  5. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  

  6. <title>Hello World</title>  

  7. </head>  

  8. <body>  

  9. ${message}  

  10. </body>  

  11. </html>  

${message}:表示显示由HelloWorldController处理器传过来的模型数据。

 

(4、启动服务器测试

地址栏输入http://localhost:9080/springmvc-chapter6/hello,我们将看到页面显示“Hello World!”,表示成功了。

 

整个过程和我们第二章中的Hello World 类似,只是处理器的实现不一样。接下来我们来看一下具体流程吧。

 

6.3、运行流程

和第二章唯一不同的两处是:

1、HandlerMapping实现:使用DefaultAnnotationHandlerMapping(spring3.1之前)或RequestMappingHandlerMapping(spring3.1)替换之前的BeanNameUrlHandlerMapping。

注解式处理器映射会扫描spring容器中的bean,发现bean实现类上拥有@Controller或@RequestMapping注解的bean,并将它们作为处理器。

 

2、HandlerAdapter实现:使用AnnotationMethodHandlerAdapter(spring3.1之前)或RequestMappingHandlerAdapter(spring3.1)替换之前的SimpleControllerHandlerAdapter。

注解式处理器适配器会通过反射调用相应的功能处理方法(方法上拥有@RequestMapping注解)。

 

好了到此我们知道Spring如何发现处理器、如何调用处理的功能处理方法了,接下来我们详细学习下如何定义处理器、如何进行请求到功能处理方法的定义。

 

6.4、处理器定义

6.4.1、@Controller

 
  1. @Controller  

  2. public class HelloWorldController {  

  3. ……  

  4. }  

推荐使用这种方式声明处理器,它和我们的@Service、@Repository很好的对应了我们常见的三层开发架构的组件。

6.4.2、@RequestMapping

 
  1. @RequestMapping  

  2. public class HelloWorldController {  

  3. ……  

  4. }  

这种方式也是可以工作的,但如果在类上使用@ RequestMapping注解一般是用于窄化功能处理方法的映射的,详见6.4.3。

package cn.javass.chapter6.web.controller;

@Controller

@RequestMapping(value="/user")                 //①处理器的通用映射前缀

public class HelloWorldController2 {

   @RequestMapping(value = "/hello2")        //②相对于①处的映射进行窄化

   public ModelAndView helloWorld() {

        //省略实现

   }

}

6.4.3、窄化请求映射

 
  1. package cn.javass.chapter6.web.controller;  

  2. @Controller  

  3. @RequestMapping(value="/user")                 //①处理器的通用映射前缀  

  4. public class HelloWorldController2 {  

  5.    @RequestMapping(value = "/hello2")        //②相对于①处的映射进行窄化  

  6.    public ModelAndView helloWorld() {  

  7.         //省略实现  

  8.    }  

  9. }  

①类上的@RequestMapping(value="/user") 表示处理器的通用请求前缀;

②处理器功能处理方法上的是对①处映射的窄化。

 

因此http://localhost:9080/springmvc-chapter6/hello2 无法映射到HelloWorldController2的 helloWorld功能处理方法;而http://localhost:9080/springmvc-chapter6/user/hello2是可以的。

窄化请求映射可以认为是方法级别的@RequestMapping继承类级别的@RequestMapping。

 

窄化请求映射还有其他方式,如在类级别指定URL,而方法级别指定请求方法类型或参数等等,后续会详细介绍。

 

到此,我们知道如何定义处理器了,接下来我们需要学习如何把请求映射到相应的功能处理方法进行请求处理。

6.5、请求映射

处理器定义好了,那接下来我们应该定义功能处理方法,接收用户请求处理并选择视图进行渲染。首先我们看一下图6-1:

 

http请求信息包含六部分信息:
①请求方法,如GET或POST,表示提交的方式;
②URL,请求的地址信息;
③协议及版本;
④请求头信息(包括Cookie信息);
⑤回车换行(CRLF);
⑥请求内容区(即请求的内容或数据),如表单提交时的参数数据、URL请求参数(?abc=123 ?后边的)等。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

http://www.656463.com/article/100

分享到:
评论

相关推荐

    SpringMVC教程

    第六章 注解式控制器详解1(注解式控制器运行流程及处理器定义).pdf 第六章 注解式控制器详解2(SpringMVC3强大的请求映射规则详解).pdf 第六章 注解式控制器详解3(生产者、消费者请求限定).pdf 第六章 注解式控制器...

    springmvc常用注解标签详解

    @Controller 只是定义了一个控制器类,而使用@RequestMapping 注解的方法才是真正处理请求的处理器。单单使用@Controller 标记在一个类上还不能真正意义上的说它就是 SpringMVC 的一个控制器类,因为这个时候 Spring...

    跟我学SpringMVC 教程

    第六章注解式控制器详解深入探讨了SpringMVC提供的注解式控制器。注解式控制器通过使用各种注解(如@Controller、@RequestMapping等)使得控制器的实现更为简洁和直观。本章不仅解析了注解式控制器的运行流程,还...

    java或Java框架中常用的注解及其作用详解_资料.docx

    - `@Component`:基础注解,用于标记任何Spring组件,包括服务、控制器和DAO。 - `@Service`:标记业务层组件,通常配合`@Autowired`使用,注入DAO组件。 - `@Repository`:标记数据访问组件,用于DAO实现。 3. ...

    跟我学Spring MVC

    #### 七、注解式控制器详解 - **注解式控制器**是Spring MVC推荐的一种控制器实现方式。 - **主要注解**: - `@Controller`:标记类为控制器。 - `@RequestMapping`:映射请求到处理方法。 - `@RequestParam`:...

    SpringBoot控制器统一的响应体编码/加密与请求体解密的注解处理方式,支持MD5/SHA/AES/DES/RSA

    以上就是关于SpringBoot控制器统一响应体编码/加密与请求体解密的注解处理方式,以及支持多种加密算法的知识点详解。通过这样的方式,我们可以有效地提高SpringBoot应用的数据安全性和应用的扩展性。

    SpringMVC 2013 内部经典教学文档 秒杀所有市面

    第六章《注解式控制器详解》: 这部分详细讲述了SpringMVC中的各种注解,如@RequestBody、@ResponseBody、@RequestParam、@PathVariable等,以及如何利用它们来处理HTTP请求参数和响应数据。 第七章《注解式控制器...

    Spring MVC 使用注解的示例讲解

    在Spring MVC中,我们可以使用@Controller注解定义一个类作为控制器,@RequestMapping注解用于映射HTTP请求。例如: ```java @Controller public class UserController { @RequestMapping("/users") public ...

    SpringMVC+MyBatis+MySql注解示例

    它的核心功能包括模型-视图-控制器(MVC)模式的实现,使得开发者可以将业务逻辑、控制流程和视图分离,提高代码的可读性和可维护性。SpringMVC通过注解可以极大地简化配置,如`@Controller`、`@RequestMapping`等,...

    跟我学SpringMVC

    **第六章 注解式控制器详解** 注解式控制器是Spring MVC的一大亮点,通过注解可以直接在方法上声明处理请求。本章详细介绍了注解的使用,如@RequestMapping、@RequestParam、@PathVariable等,以及Spring MVC的请求...

    springMVC详解以及注解说明

    3. **Controller**:控制器处理业务逻辑,返回 ModelAndView 对象,包含了视图名和模型数据。 4. **ModelAndView**:包含了视图名和模型数据,用于传递数据到视图层。 5. **ViewResolver**:解析视图名,找到实际...

    详解spring注解式参数校验

    总结起来,Spring注解式参数校验提供了强大的数据验证功能,通过简单的注解就能在控制器层进行参数的有效性检查,极大地提高了代码的可读性和维护性。同时,结合自定义验证逻辑,可以灵活应对各种复杂的业务场景。

    SpringMVC详解

    4. **注解式控制器** 从Spring 3.0开始,SpringMVC引入了注解式编程,使得开发者可以直接在方法上使用@RequestMapping等注解来定义请求映射,极大地简化了配置。此外,还可以使用@ModelAttribute、@RequestParam、@...

    spring和Struts2注解文档

    Spring注解主要应用于依赖注入、控制器定义、事务管理、缓存控制等方面。 ##### 1.1.1 注册注解处理器 Spring容器能够识别特定的注解,并通过注解处理器(Annotation Processor)来执行相应的操作。例如,`@...

Global site tag (gtag.js) - Google Analytics