1 <context:annotation-config/>
- 如果你想使用
@Autowired
注解,那么就必须事先在 spring 容器中声明 AutowiredAnnotationBeanPostProcessor Bean. - 如果想使用
@Resource
,@PostConstruct
,@PreDestroy
等注解就必须声明CommonAnnotationBeanPostProcessor - 如果想使用
@PersistenceContext
注解,就必须声明PersistenceAnnotationBeanPostProcessor的Bean. - 如果想使用
@Required
的注解,就必须声明RequiredAnnotationBeanPostProcessor的Bean.
使用<context:annotation- config/>
隐式地向 Spring容器注册这4个BeanPostProcessor :
AutowiredAnnotationBeanPostProcessorRequiredAnnotationBeanPostProcessorCommonAnnotationBeanPostProcessorPersistenceAnnotationBeanPostProcessor
即<context:annotation-config/>
是用来使上述注解起作用的,也就是说激活已经在application context中注册的bean.
<context:annotation-config/>
仅能够在spring容器中已经注册过的bean上面起作用.对于没有在spring容器中注册的bean,它并不能执行任何操作,也就是说如果你并没有spring容器中注册过bean(spring配置文件中配置bean就是注册),那么上述的那些注解并不会在你未注册过的bean中起作用. 2 <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/>
3 <mvc:annotation-driven/>
至于该项看前缀就应该知道是springmvc所需要的注解.
<mvc:annotation-driven/>
相当于注册了DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter两个bean,配置一些messageconverter.即解决了@Controller
注解的使用前提配置.
我们找到对应的实现类是:
org.springframework.web.servlet.config.AnnotationDrivenBeanDefinitionParser.
通过阅读类注释文档,我们发现这个类主要是用来向工厂中注册了RequestMappingHandlerMappingBeanNameUrlHandlerMappingRequestMappingHandlerAdapterHttpRequestHandlerAdapterSimpleControllerHandlerAdapterExceptionHandlerExceptionResolverResponseStatusExceptionResolverDefaultHandlerExceptionResolver
上面几个Bean实例.这几个类都是用来做什么的呢?
前两个是HandlerMapping接口的实现类,用来处理请求映射的.
- 其中第一个是处理
@RequestMapping
注解的. - 第二个会将controller类的名字映射为请求url.
中间三个是用来处理请求的.具体点说就是确定调用哪个controller的哪个方法来处理当前请求.
- 第一个处
理@Controller
注解的处理器,支持自定义方法参数和返回值(很酷). - 第二个是处理继承HttpRequestHandler的处理器.
- 第三个处理继承自Controller接口的处理器.
后面三个是用来处理异常的解析器.
另外还将提供以下支持:
① 支持使用ConversionService实例对表单参数进行类型转换; ② 支持使用@NumberFormatannotation,@DateTimeFormat注解完成数据类型的格式化; ③ 支持使用@Valid注解对Java bean实例进行JSR 303验证; ④ 支持使用@RequestBody和@ResponseBody注解转自:https://blog.csdn.net/caolaosanahnu/article/details/17305135