SpringIOC常用注解
组件添加
- @ComponentScan 包扫描
- basePackages,注解的value属性,指定要扫描的包
- includeFilters 包含的扫描条件
- excludeFilters 排除的过滤条件
- 例: excludeFilters={@Filter(type=FilterType.ANNOTATION,class={Controller.class})} (排除Controller注解)
- FilterType.ANNOTATION:按照注解过滤
- FilterType.ASSIGNABLE_TYPE:按照给定的类型
- FilterType.ASPECTJ:使用ASPECTJ表达式
- FilterType.REGEX:正则
- FilterType.CUSTOM:自定义规则
- basePackageClasses,指定要扫描的类
- nameGenerator bean的名称生成器,默认BeanNameGenerator
- useDefaultFilters 是否开启对标注@Component @Controller @Service @Repository的类进行扫描
- @Configuration 标明配置类,内部继承@Component
- @Bean 将方法返回值作为组件注册
- name 默认值,组件在容器中的名称
- initMethod 初始化方法,等同于实现InitializationBean接口(不推荐),可以用@PostConstruct替代
- destroyMethod 容器销毁方法,等同于实现DisposableBean 接口(不推荐),可以用@PreDestory代替
- @Component @Controller @Service @Repository 将相应的类注册到spring中
- @Primary 结合@Autowire,注入时同类型下优先选择本组件
- @Lazy单例下懒加载
- @Lazy(“true”) 懒加载,对象第一次被访问时创建
- @Lazy(“false”) spring初始化时创建
- @Scope指定组件作用域
- @Scope(“singleton”) 组件单例
- @Scope(“prototype”) 原型,每次请求会创建一个新的bean
- @Scope(“request”) web项目中,每个request域,创建一次
- @Scope(“session”) web项目中,每个session域,创建一次
- @Scope(“global session”) 基于portlet的web项目中,每个全局session的生命周期中,只会创建一次
- @Import 快速给容器中导入一个组件
- @Import({组件的Class})(可以传数组),组件在ioc容器中的名称是组件的全类名
- @Import(实现了ImportSelector接口的Class) 接口中返回了包含组件全类名的数组,Spring会将这些类放入容器中
- @Import(实现了ImportSelector接口的Class) 如果实现了ImportSelector会,调用该类中的registeBeanDefination方法,(方法中用BeanDefinationRegisty注册组件)
- @Conditional({实现了Condition接口的Class}) Condition接口返回Boolean,如果true注册bean,反之不注册
组件赋值
-
@Value
- 常规值 @Value(“张三”)
- SPEL表达式 @Value("#{10*2}")
- 从配置文件中取值 @Value("${配置文件中的key}") 需要使用@propertySourse预先读取配置文件
-
@AutoWire,@Qualifier,@Resources,@Inject
- @Resources,@Inject 是java中定义的注解,@AutoWire和@Qualifier是spring定义的
- @AutoWire和@Inject作用基本相同,@AutoWire可设置required属性,容器中没有找到bean时也不报错,@Inject使用时要单独导包,两者都可结合@Qualifier使用,查找优先级
- 按类型匹配
- 按Qualifier匹配
- 按名称匹配
- @Resource执行优先级
- 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常。
- 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常。
- 如果指定了type,则从上下文中找到类似匹配的唯一bean进行装配,找不到或是找到多个,都会抛出异常。
- 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配。
-
@propertySourse 用于加载.properties类型配置文件,可以在多次标注,也可传String数组
- 例: @PropertySourse(“classpath:/dataBase.properties”)
-
@Profile(“环境标识”) spring会查找spring.profiles.actives,如果没有设置,会再查找spring.profiles.default,符合则注入容器,否则忽略该类或方法,spring.profiles.actives设置方法,
-
web.xml中配置
<context-param> <param-name>spring.profiles.default</param-name> <param-value>dev</param-value> </context-param>
-
作为DispatcherServlet的初始化参数
<servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:/spring-servlet.xml</param-value> </init-param> <init-param> <param-name>spring.profiles.default</param-name> <param-value>dev</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet>
-
spring-junit使用@ActiveProfiles进行激活
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "/spring-config.xml") @ActiveProfiles("dev") public class MainTest { ... }
-