三、Bean定义

1、开启bean定义注解支持

开启注解支持须添加以下配置项:

<context:component-scan base-package="cn.matt"/>  

2、支持bean定义的注解

Spring自带@Component注解及扩展@Repository、@Service、@Controller,用于定义bean,如图所示

上述注解默认的bean名字是以小写开头的类名(不包含包名),bean的名字也可由注解的value属性明确指定

@Service
public class ServiceAImpl {
...
}
// 默认bean名称:serviceAImpl
@Service("myService")
public class ServiceAImpl {
...
}
// 明确指定

3、自定义扩展

可在@Component、@Repository@Service、@Controller基础上,定义自己的注解

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Service
public @interface MyService {
String value() default "";
}

注意,value属性可指定bean名称,与spring自带注解相同

4、细粒度控制Bean定义扫描

<context:component-scan>标签支持细粒度控制Bean定义扫描

<context:component-scan
base-package=""
resource-pattern="**/*.class"
name-generator="org.springframework.context.annotation.AnnotationBeanNameGenerator"
use-default-filters="true"
annotation-config="true">
<context:include-filter type="aspectj" expression=""/>
<context:exclude-filter type="regex" expression=""/>
</context:component-scan>

属性说明:

  • base-package表示扫描注解类的开始位置,即将在指定的包中扫描,其他包中的注解类将不被扫描,默认将扫描所有类路径。
  • resource-pattern表示扫描注解类的后缀匹配模式,即“base-package+resource-pattern”将组成匹配模式用于匹配类路径中的组件,默认后缀为“**/*.class”,即指定包下的所有以.class结尾的类文件。
  • name-generator默认情况下的Bean标识符生成策略,默认是AnnotationBeanNameGenerator,其将生成以小写开头的类名(不包括包名),也可以自定义自己的标识符生成策略。
  • use-default-filters默认为true表示过滤@Component、@ManagedBean、@Named注解的类,如果改为false默认将不过滤这些默认的注解来定义Bean,即这些注解类不能被过滤到,即不能通过这些注解进行Bean定义。
  • annotation-config表示是否自动支持注解实现Bean依赖注入,默认支持,如果设置为false,将关闭支持注解的依赖注入,需要通过<context:annotation-config/>开启。

过滤器说明:

  • <context:include-filter>表示过滤到的类将被注册为Spring管理Bean。
  • <context:exclude-filter>表示过滤到的类将不被注册为Spring管理Bean,它比<context:include-filter>具有更高优先级。
  • type表示过滤器类型,目前支持注解类型、类类型、正则表达式、aspectj表达式过滤器,当然也可以自定义自己的过滤器,实现org.springframework.core.type.filter.TypeFilter即可。
  • expression表示过滤器表达式。

过滤器使用示例:

<!-- 类 -->
<context:include-filter type="assignable" expression="cn.matt.TestBean1"/> <!-- 注解 -->
<context:include-filter type="annotation" expression="org.aspectj.lang.annotation.Aspect"/> <!-- 正则表达式 -->
<context:exclude-filter type="regex" expression="cn\.matt\.TestBean2*"/>

Spring MVC中的典型配置:

<!-- spring-context.xml中的配置 -->
<context:component-scan base-package="com.wind.pac" use-default-filters="true">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />
</context:component-scan> <!-- spring-mvc.xml中的配置 -->
<context:component-scan base-package="com.wind.pac" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
<context:include-filter type="annotation" expression="org.springframework.web.bind.annotation.RestController" />
</context:component-scan>

5、其他配置

i)@Lazy:定义Bean将延迟初始化

@Component("component")
@Lazy(true)
public class TestCompoment {
...
}

ii)@Scope:定义Bean作用域,默认单例

@Component("component")
@Scope("singleton")
public class TestCompoment {
...
}

iii)@Qualifier:指定限定描述符,对应于基于XML配置中的<qualifier>标签

@Component("component")
@Qualifier("component")
public class TestCompoment {
...
}

iv)@Primary:自动装配时当出现多个Bean候选者时,被注解为@Primary的Bean将作为首选者,否则将抛出异常

@Component("component")
@Primary
public class TestCompoment {
...
}

 四、Java类替换配置文件

1、简单示例

简单类

public class Girl {
@Autowired
private String name; public String getName() {
return name;
}
}

配置元数据的java类

@Configuration
public class MyConfig {
@Bean
public String myGirl() {
return "qqm";
} @Bean
public Girl girl() {
return new Girl();
}
}

测试

public class ConfigTest {
@Test
public void test() { AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(MyConfig.class);
Assert.assertTrue(StringUtils.equals("qqm", context.getBean("myGirl", String.class))); Girl girl = context.getBean(Girl.class);
Assert.assertTrue(StringUtils.equals("qqm", girl.getName()));
}
}

2、详细介绍

i)@Configuration

  • 通过@Configuration注解的类将被作为配置类使用,表示在该类中将定义Bean配置元数据
  • @Configuration是@Component注解的扩展,因此@Configuration注解的类本身也是一个Bean
  • @Configuration注解的类不能是final的,且应该有一个默认无参构造器
  • 使用AnnotationConfigApplicationContext 指定配置类时,@Configuration注解可省略

ii)@Bean

@Bean(name={},
autowire=Autowire.NO,
initMethod="",
destroyMethod="")
  • name:指定Bean的名字,可有多个,第一个作为Id,其他作为别名
  • autowire:自动装配,默认no表示不自动装配该Bean
  • initMethod和destroyMethod:指定Bean的初始化和销毁方法
  • 对于依赖注入,可使用赋值的方式注入(如同创建一个实体并赋值),也可使用注解的方式注入(不需要开启注解,如上例)

iii)引入其他配置

引入基于java方式的配置类

@Configuration
@Import({MyConfig2.class})
public class MyConfig {
...
}

引入基于XML的配置

@Configuration
@ImportResource("classpath:spring-context.xml")
public class ApplicationContextConfig {
...
}

3、XML配置中引入Java方式的配置

XML开启bean定义支持,并扫描到@Configuration配置类,即可引入

参考:

第十二章 零配置 之 12.3 注解实现Bean定义 ——跟我学spring3

第十二章 零配置 之 12.4 基于Java类定义Bean配置元数据 ——跟我学spring3

Spring 使用介绍(九)—— 零配置(二)的更多相关文章

  1. Parcel.js + Vue 2.x 极速零配置打包体验

    继 Browserify.Webpack 之后,又一款打包工具 Parcel 横空出世 Parcel.js 的官网有这样的自我介绍 “极速零配置Web应用打包工具” 简单接触了一下,单从效率上来说,确 ...

  2. Parcel + Vue 2.x 极速零配置打包体验

    继 Browserify.Webpack 之后,又一款打包工具 Parcel 横空出世 Parcel.js 的官网有这样的自我介绍 “极速零配置Web应用打包工具” 简单接触了一下,单从效率上来说,确 ...

  3. Spring Cloud 微服务入门(二)--Spring Cloud 架构

    Spring Cloud整体核心架构:Rest服务,在Spring Cloud配置过程中,都是遵循Rest风格规范,在Rest处理中,必不可少两个对象端:服务的提供者(provider)和服务消费者( ...

  4. Spring4.X + spring MVC + Mybatis3 零配置应用开发框架搭建详解(1) - 基本介绍

    Spring4.X + spring MVC + Mybatis3 零配置应用开发框架搭建详解(1) - 基本介绍 spring集成 mybatis Spring4.x零配置框架搭建 两年前一直在做后 ...

  5. Spring 使用介绍(八)—— 零配置(一)

    一.概述 所谓零配置,并不是说一点配置都没有了,而是配置很少而已.通过约定来减少需要配置的数量,提高开发效率. 零配置实现主要有以下两种方式: 惯例优先原则:也称为约定大于配置(convention ...

  6. Spring 基于注解零配置开发

    本文是转载文章,感觉比较好,如有侵权,请联系本人,我将及时删除. 原文网址:< Spring 基于注解零配置开发 > 一:搜索Bean 再也不用在XML文件里写什么配置信息了. Sprin ...

  7. 基于纯Java代码的Spring容器和Web容器零配置的思考和实现(3) - 使用配置

    经过<基于纯Java代码的Spring容器和Web容器零配置的思考和实现(1) - 数据源与事务管理>和<基于纯Java代码的Spring容器和Web容器零配置的思考和实现(2) - ...

  8. spring+hibernate+struts2零配置整合

    说句实话,很久都没使用SSH开发项目了,但是出于各种原因,再次记录一下整合方式,纯注解零配置. 一.前期准备工作 gradle配置文件: group 'com.bdqn.lyrk.ssh.study' ...

  9. Spring 使用介绍(十二)—— Spring Task

    一.概述 1.jdk的线程池和任务调用器分别由ExecutorService.ScheduledExecutorService定义,继承关系如下: ThreadPoolExecutor:Executo ...

随机推荐

  1. EntityFramework Core并发深挖详解,一纸长文,你准备好看完了吗?

    前言 之前有关EF并发探讨过几次,但是呢,博主感觉还是有问题,为什么会觉得有问题,其实就是理解不够透彻罢了,于是在项目中都是用的存储过程或者SQL语句来实现,利用放假时间好好补补EF Core并发的问 ...

  2. nrf2401 - 最廉价的2.4G无线通信方案

    所有的使用Arduino 的朋友大多都会知道大名鼎鼎的XBee 这个土豪级的ZigBee 的通信模块.我们是做产品开发的,对于XBee这个产品可谓是又爱又恨,不得不承认他确实是一个好货,从做工到功能都 ...

  3. flask使用基础

    1.安装 pip install Flask 基本依赖库: jinja2:实现对模板的处理 werkzeug:本质是socket服务器,用于接收http请求,并对请求进行预处理,然后触发Flaks框架 ...

  4. Javascript 综合示例 网页扫雷游戏

    ---------------认定了的事情,只要是对的,干到底! ------------------------------------------------------------------- ...

  5. Python_装饰器习题_31

    # 1.编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件), # 要求登录成功一次,后续的函数都无需再输入用户名和密码 FLAG = False def login(func): def ...

  6. Atcoder E - Knapsack 2 (01背包进阶版 ex )

    E - Knapsack 2 Time Limit: 2 sec / Memory Limit: 1024 MB Score : 100100 points Problem Statement The ...

  7. 黑客帝国效果赏析(包含ES6的语法)

    首先,看看效果吧. 代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  8. ibeacon和蓝牙有什么区别_它们的区别在哪里

    iBeacon概述 iBeacon是苹果公司2013年9月发布的移动设备用OS(iOS7)上配备的新功能.其工作方式是,配备有低功耗蓝牙(BLE)通信功能的设备使用BLE技术向周围发送自己特有的ID, ...

  9. python的UnboundLocalError: local variable 'xxx' referenced b

    一.意思: 本地变量xxx引用前没定义. 二.错误原因     在于python没有变量的声明 , 所以它通过一个简单的规则找出变量的范围 :如果有一个函数内部的变量赋值 ,该变量被认为是本地的,所以 ...

  10. Centos 6.x 升级到 7.x

    Centos6.5跨越大版本升级到Centos7.4 - Linux学习与应用 - CSDN博客https://blog.csdn.net/whbttst/article/details/805348 ...