- spring容器的配置方式:
主要包含以下三种,
(1)通过XML文件;
(2)通过注解;
(3)通过java代码;
当然,以上三种当时协同配合的效果会更好。XML配置容器比较清楚,但灵活性不好;使用java代码配置容器,可以实现更加强大的功能,更加灵活,可以自己决定容器中的Bean产生的方式,但仍然需要注解的配合,才能完成对容器的配置。下面是一个配置Spring容器的例子:
@Configuration
@EnableWebMvc
@ComponentScan("org.kinard.controller")
public class WebAppConfig {
/*配置视图解析器
* 想使用多个视图解析器,可以设置不同解析器的优先级.*/
@Bean
public ViewResolver viewResolver_0() {
InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
viewResolver.setPrefix("/views/jsp/");
viewResolver.setSuffix(".jsp");
/*设置解析器的优先级,当含有其他类型的视图解析器时,
InternalResourceViewResolver应该设置成最低的优先级*/
//viewResolver.setOrder(3);
return viewResolver;
}
}
其中:
注解@Configuration表示这是一个容器配置类;
注解@EnableWebMvc表示启用WebMvc;
注解@ComponentScan表示使用Spring的自动扫描机制,发现指定的包下被某些注解标识的Bean,发现之后会自动配置到Spring容器之中(这和XML配置的方式类似,也有自动扫描);
类中的@Bean注解作用在方法上,表示该方法的返回对象会作为一个Bean配置到容器之中,示例代码配置了视图解析器;
在实际项目中可以根据需要写多个这样的配置类;
- 整合配置好的容器:
按照需要写好上述的配置类之后,还需要一步整合工作,从类名可以看出,下面的代码将完成对DispatcherServlet的初始化工作,告诉Spring哪些配置类是Root的容器,哪些是下一级别的容器,以及这个DispatcherServlet处理的URL是什么,方法的返回值都是某类型的数组,表明可以配置多个:
import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
public class BasicDispatcherInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class[0];
}
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[]{WebAppConfig.class};
}
@Override
protected String[] getServletMappings() {
return new String[]{"/user/*"};
}
}