SpringMVC - <context:annotation-config/>与<mvc:annotation-driven/>和<context:component-scan>
2017-08-19 21:18
537 查看
现在常用框架中SpringMVC.xml配置是:
1
那么
首先看一下三个注解各自定义:
①
1.如果你想使用@Autowired注解,那么就必须事先在 spring 容器中声明 AutowiredAnnotationBeanPostProcessor Bean。
2.如果想使用@Resource 、@PostConstruct、@PreDestroy等注解就必须声明CommonAnnotationBeanPostProcessor
3.如果想使用@PersistenceContext注解,就必须声明PersistenceAnnotationBeanPostProcessor的Bean。
4.如果想使用 @Required的注解,就必须声明RequiredAnnotationBeanPostProcessor的Bean。
使用
2
3
4
5
6
1
2
3
4
5
6
即
之所以这样说是因为
②
2
3
4
1
2
3
4
所以配置
③
至于该项看前缀就应该知道是springmvc所需要的注解。
我们找到对应的实现类是:
2
1
2
通过阅读类注释文档,我们发现这个类主要是用来向工厂中注册了
RequestMappingHandlerMapping
BeanNameUrlHandlerMapping
RequestMappingHandlerAdapter
HttpRequestHandlerAdapter
SimpleControllerHandlerAdapter
ExceptionHandlerExceptionResolver
ResponseStatusExceptionResolver
DefaultHandlerExceptionResolver
上面几个Bean实例。这几个类都是用来做什么的呢?
前两个是HandlerMapping接口的实现类,用来处理请求映射的。
其中第一个是处理@RequestMapping注解的。
第二个会将controller类的名字映射为请求url。
中间三个是用来处理请求的。具体点说就是确定调用哪个controller的哪个方法来处理当前请求。
第一个处理@Controller注解的处理器,支持自定义方法参数和返回值(很酷)。
第二个是处理继承HttpRequestHandler的处理器。
第三个处理继承自Controller接口的处理器。
后面三个是用来处理异常的解析器。
另外还将提供以下支持:
① 支持使用ConversionService实例对表单参数进行类型转换;
② 支持使用@NumberFormatannotation、@DateTimeFormat注解完成数据类型的格式化;
③ 支持使用@Valid注解对Java bean实例进行JSR 303验证;
④ 支持使用@RequestBody和@ResponseBody注解
原文地址:http://blog.csdn.net/j080624/article/details/60883328
<mvc:annotation-driven/>和<context:component-scan>1
1
那么
<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 :
AutowiredAnnotationBeanPostProcessor、 RequiredAnnotationBeanPostProcessor、 CommonAnnotationBeanPostProcessor以及 PersistenceAnnotationBeanPostProcessor1
2
3
4
5
6
1
2
3
4
5
6
即
<context:annotation- config/>是用来使上述注解起作用的,也就是说激活已经在application context中注册的bean。
之所以这样说是因为
<context:annotation-config />仅能够在已经在已经注册过的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并且在application context中注册扫描的beans.1
2
3
4
1
2
3
4
所以配置
<context:component-scan>就不需要配置
<context:annotation- config/>
③
<mvc:annotation-driven/>
至于该项看前缀就应该知道是springmvc所需要的注解。
我们找到对应的实现类是:
org.springframework.web.servlet.config.AnnotationDrivenBeanDefinitionParser。1
2
1
2
通过阅读类注释文档,我们发现这个类主要是用来向工厂中注册了
RequestMappingHandlerMapping
BeanNameUrlHandlerMapping
RequestMappingHandlerAdapter
HttpRequestHandlerAdapter
SimpleControllerHandlerAdapter
ExceptionHandlerExceptionResolver
ResponseStatusExceptionResolver
DefaultHandlerExceptionResolver
上面几个Bean实例。这几个类都是用来做什么的呢?
前两个是HandlerMapping接口的实现类,用来处理请求映射的。
其中第一个是处理@RequestMapping注解的。
第二个会将controller类的名字映射为请求url。
中间三个是用来处理请求的。具体点说就是确定调用哪个controller的哪个方法来处理当前请求。
第一个处理@Controller注解的处理器,支持自定义方法参数和返回值(很酷)。
第二个是处理继承HttpRequestHandler的处理器。
第三个处理继承自Controller接口的处理器。
后面三个是用来处理异常的解析器。
另外还将提供以下支持:
① 支持使用ConversionService实例对表单参数进行类型转换;
② 支持使用@NumberFormatannotation、@DateTimeFormat注解完成数据类型的格式化;
③ 支持使用@Valid注解对Java bean实例进行JSR 303验证;
④ 支持使用@RequestBody和@ResponseBody注解
原文地址:http://blog.csdn.net/j080624/article/details/60883328
相关文章推荐
- <mvc:annotation-driven/>、<context:component-scan base-package=""/>、<context:annotation-config/>的用法
- Spring <context:annotation-config/> <context:component-scan/>与<mvc:annotation-driven />
- <mvc:annotation-driven/>,<context:annotation-config/>,<context:component-scan/>详解
- <context:annotation-config/>,<mvc:annotation-driven/>和<context:component-scan>之间的关系
- <mvc:annotation-driven/> <context:annotation-config/> <context:component-scan>
- <context:annotation-config/>,<mvc:annotation-driven/>和<context:component-scan>之间的关
- <context:annotation-config/>,<mvc:annotation-driven/>和<context:component-scan>之间的关系
- <context:annotation-config/>,<context:component-scan/>,<mvc:annotation-driven/>区分
- <mvc:annotation-driven/>、<context:component-scan base-package=""/>、<context:annotation-config/>的用法
- <context:component-scan/> <mvc:annotation-driven /> 区别
- Spring mvc——接收对象Json数据,<mvc:annotation-driven/><context:annotation-config/><context:component-scan/>
- <context:component-scan>扫描@Component @Controller@Service注解的的类 <mvc:annotation-driven />启用注解
- spring mvc <mvc:annotation-driven/> 和<context:component-scan base-package=""/>解释
- Spring配置文件详解:<context:annotation-config/>和<context:component-scan base-package=""/>和<mvc:annotation-driven />
- <mvc:annotation-driven /><context:annotation-config/><context:component-scan/>
- Spring <context:component-scan/>与<mvc:annotation-driven/>
- <mvc:annotation-driven >和<context:component-scan>
- <mvc:annotation-driven/>、<context:component-scan base-package=""/>、<context:annotation-config/>的用法
- 先码后看 <context:annotation-config/>、<mvc:annotation-driven/>以及<context:component-scan> 侵立删
- Spring配置文件详解一:<context:annotation-config/>与<context:component-scan base-package="com.x