mvc:annotation-driven和context:component-scan之间的关系

https://segmentfault.com/a/1190000012193685

现在常用框架中SpringMVC.xml配置是:
<mvc:annotation-driven/><context:component-scan>
那么<context:annotation-config/>呢?
首先看一下三个注解各自定义:

<context:annotation-config/>

  1. 如果你想使用@Autowired注解,那么就必须事先在 spring 容器中声明 AutowiredAnnotationBeanPostProcessor Bean.
  2. 如果想使用@Resource ,@PostConstruct,@PreDestroy等注解就必须声明CommonAnnotationBeanPostProcessor
  3. 如果想使用@PersistenceContext注解,就必须声明PersistenceAnnotationBeanPostProcessor的Bean.
  4. 如果想使用 @Required的注解,就必须声明RequiredAnnotationBeanPostProcessor的Bean.

使用<context:annotation- config/>隐式地向 Spring容器注册这4个BeanPostProcessor :

 

<context:annotation-config/>是用来使上述注解起作用的,也就是说激活已经在application context中注册的bean
之所以这样说是因为<context:annotation-config/>仅能够在spring容器中已经注册过的bean上面起作用.对于没有在spring容器中注册的bean,它并不能执行任何操作,也就是说如果你并没有spring容器中注册过bean(spring配置文件中配置bean就是注册),那么上述的那些注解并不会在你未注册过的bean中起作用.

<context:component-scan>

<context:component-scan>做了<context:annotation-config>要做的事情,还额外支持@Component@Repository@Service@Controller注解.并且<context:component-scan>扫描base-package并且在applicationcontext中注册扫描的beans.

所以配置<context:component-scan>就不需要配置<context:annotation- config/>

<mvc:annotation-driven/>

至于该项看前缀就应该知道是springmvc所需要的注解.

<mvc:annotation-driven/>相当于注册了DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter两个bean,配置一些messageconverter.即解决了@Controller注解的使用前提配置.

我们找到对应的实现类是:

org.springframework.web.servlet.config.AnnotationDrivenBeanDefinitionParser.
通过阅读类注释文档,我们发现这个类主要是用来向工厂中注册了

 

上面几个Bean实例.这几个类都是用来做什么的呢?

前两个是HandlerMapping接口的实现类,用来处理请求映射的.

  • 其中第一个是处理@RequestMapping注解的.
  • 第二个会将controller类的名字映射为请求url.

中间三个是用来处理请求的.具体点说就是确定调用哪个controller的哪个方法来处理当前请求.

  • 第一个处理@Controller注解的处理器,支持自定义方法参数和返回值(很酷).
  • 第二个是处理继承HttpRequestHandler的处理器.
  • 第三个处理继承自Controller接口的处理器.

后面三个是用来处理异常的解析器.

另外还将提供以下支持:
① 支持使用ConversionService实例对表单参数进行类型转换; 
② 支持使用@NumberFormatannotation,@DateTimeFormat注解完成数据类型的格式化; 
③ 支持使用@Valid注解对Java bean实例进行JSR 303验证; 
④ 支持使用@RequestBody和@ResponseBody注解

转自:http://blog.csdn.net/sunhuwh/...
<annotaion-driven/>标签:这个标签对应的实现类是org.springframework.web.servlet.config.AnnotationDrivenBeanDefinitionParser

仔细阅读它的注释文档可以很明显的看到这个类的作用.解析这个文档:

这个类主要注册8个类的实例:

 

1是处理@RequestMapping注解的,2.将controller类的名字映射为请求url.1和2都实现了HandlerMapping接口,用来处理请求映射.

3是处理@Controller注解的控制器类,4是处理继承HttpRequestHandlerAdapter类的控制器类,5.处理继承SimpleControllerHandlerAdapter类的控制器.所以这三个是用来处理请求的.具体点说就是确定调用哪个controller的哪个方法来处理当前请求.

6,7,8全部继承AbstractHandlerExceptionResolver,这个类实现HandlerExceptionResolver,该接口定义:接口实现的对象可以解决处理器映射,执行期间抛出的异常,还有错误的视图.

所以<annotaion-driven/>标签主要是用来帮助我们处理请求映射,决定是哪个controller的哪个方法来处理当前请求,异常处理.

<context:component-scan/>标签:它的实现类是org.springframework.context.annotation.ComponentScanBeanDefinitionParser.

把鼠标放在context:component-scan上就可以知道有什么作用的,用来扫描该包内被@Repository,@Service,@Controller的注解类,然后注册到工厂中.并且context:component-scan激活@required,@resource,@autowired,@PostConstruct,@PreDestroy,@PersistenceContext,@PersistenceUnit.使得在适用该bean的时候用@Autowired就行了.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值