spring <context:component-scan />及<mvc:annotation-driven />使用说明

来源:互联网 发布:iphone 贴图软件推荐 编辑:程序博客网 时间:2024/06/06 03:57

转载自http://blog.csdn.net/u011079274/article/details/51477287

从spring 2.5版本开始,就开始支持注解注入了,使用注解可以省掉很多在xml中的配置,使配置文件更加的简洁。在我们的spring配置文件当中,经常会碰到<context:component-scan /><mvc:annotation-driven />这样的配置,那到底这两个配置帮我们做了哪些工作呢?

<context:component-scan />

从spring2.5版本开始,提供了一个强大的组件扫描功能。它能够自动从classpath中扫描、检测和实例化你的bean。当我们在spring配置文件当中添加了<context:component-scan />这个xml元素,就表示启动spring的组件扫描功能。指定属性base-package(包名),表示将扫描base-package包或者子包下面的java文件,如果扫描到有@controller、@Service、@Repository、@Component等注解的java类,就会将这些类注册为bean。还可以使用分号来分隔多个扫描包。
如果在配置文件中配置了<context:component-scan />,就不用在配置<context:annotation-config/>,因为前者已经包含了后者。<context:annotation-config/>的作用是向spring容器注入AutowiredAnnotationBeanPostProcessor、CommonAnnotationBeanPostProcessor、PersistenceAnnotationBeanPostProcessor 及RequiredAnnotationBeanPostProcessor 四个beanPostProcessor。如果你想使@Autowired注解生效,能够自动注入,就必须向spring容器声明AutowiredAnnotationBeanPostProcessor,形如:

<bean class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/>

相对应的,你想使用@Resource、@PostConstruct、@PreDestroy等注解,就要声明CommonAnnotationBeanPostProcessor。
如果想使用@PersistenceContext就得声明PersistenceAnnotationBeanPostProcessor 。
如果想使用@Required注解得声明RequiredAnnotationBeanPostProcessor。

一般这几个注解还是经常使用的,比如@Autowired和@Resource进行自动注入时经常使用,还有@PostConstruct、@PreDestroy注解,表示在bean的初始化和销毁时调用到的方法。我们看到,如果想使用这些注解,按传统的方式每次一条一条的去声明配置过于繁琐,而且配置多了后可读性也变差了。帮我们注入4个bean后处理器,极大的简化我们的配置。

<mvc:annotation-driven />

在spring MVC中,<context:component-scan />能够启动组件扫描实例化bean,并完成自动注入。但是,URL请求映射到控制器类及其对应的处理方法,这个就需要Web应用有更多的声明。一般我们采用@RequestMapping注解来完成映射关系,还必须向上下文中注册DefaultAnnotationHandlerMapping和一个AnnotationMethodHandlerAdapter实例。这两个实例分别在类级别和方法级别处理@RequestMapping注解。形如这样:

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" /><bean   class="org.springframework.web.servlet.mvc.annotation. AnnotationMeth odHandlerAdapter"/><context:component-scan base-package="" />

<mvc:annotation-driven/>配置能够帮我们省去DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter的声明配置。同时,还提供了数据绑定支持,@NumberFormatannotation支持,@DateTimeFormat支持,@Valid支持,读写XML的支持(JAXB),读写JSON的支持(Jackson)。其中对json的处理是我们项目中经常用到的,使用Jackson库将对象序列化为json字符串。所以我们的项目中,也必须含有jackson的jar包。当我们返回的数据不是html标签的页面时,而是其他格式的数据时(如xml、json等),我们使用@ResponseBody注解,将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。

阅读全文
0 0
原创粉丝点击