码迷,mamicode.com
首页 > 编程语言 > 详细

Spring Bean配置2

时间:2016-09-02 15:54:25      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:

Spring表达式语言:SpEL

Spring 表达式语言(简称SpEL):是一个支持运行时查询和操作对象图的强大的表达式语言
语法类似于 EL:SpEL 使用 #{…} 作为定界符,所有在大框号中的字符都将被认为是 SpEL
SpEL 为 bean 的属性进行动态赋值提供了便利
•通过 SpEL 可以实现:
  –通过 bean 的 id 对 bean 进行引用
  –调用方法以及引用对象中的属性
  –计算表达式的值

  –正则表达式的匹配

SpEL:字面量

•字面量的表示:

  –整数:<property name="count" value="#{5}"/>
  –小数:<property name="frequency" value="#{89.7}"/>
  –科学计数法:<property name="capacity" value="#{1e4}"/>
  –String可以使用单引号或者双引号作为字符串的定界符号:<property name=“name” value="#{‘Chuck‘}"/> 或 <property name=‘name‘ value=‘#{"Chuck"}‘/>
  –Boolean:<property name="enabled" value="#{false}"/>

SpEL:引用 Bean、属性和方法

•引用其他对象:

  技术分享

•引用其他对象的属性

  技术分享

•调用其他方法,还可以链式操作

  技术分享
  技术分享

•调用静态方法或静态属性:通过 T() 调用一个类的静态方法,它将返回一个 Class Object,然后再调用相应的方法或属性:

  技术分享

SpEL支持的运算符号

•算数运算符:+, -, *, /, %, ^:

  技术分享

•加号还可以用作字符串连接:

  技术分享

•比较运算符: <, >, ==, <=, >=, lt, gt, eq, le, ge

  技术分享
  技术分享

•逻辑运算符号: and, or, not, |

  技术分享

•if-else 运算符:?: (ternary), ?: (Elvis)

  技术分享

•if-else 的变体

  技术分享

•正则表达式:matches

  技术分享

IOC 容器中 Bean 的生命周期方法

•Spring IOC 容器可以管理 Bean 的生命周期, Spring 允许在 Bean 生命周期的特定点执行定制的任务.

•Spring IOC 容器对 Bean 的生命周期进行管理的过程:

  –通过构造器或工厂方法创建 Bean 实例
  –为 Bean 的属性设置值和对其他 Bean 的引用
  –调用 Bean 的初始化方法
  –Bean 可以使用了
  –当容器关闭时, 调用 Bean 的销毁方法
•在 Bean 的声明里设置 init-method 和 destroy-method 属性, 为 Bean 指定初始化和销毁方法.

创建 Bean 后置处理器

•Bean 后置处理器允许在调用初始化方法前后对 Bean 进行额外的处理.
•Bean 后置处理器对 IOC 容器里的所有 Bean 实例逐一处理, 而非单一实例. 其典型应用是: 检查 Bean 属性的正确性或根据特定的标准更改 Bean 的属性.
•对Bean 后置处理器而言, 需要实现 BeanPostProcessor 接口. 在初始化方法被调用前后, Spring 将把每个 Bean 实例分别传递给上述接口的以下两个方法:
  public Object postProcessAfterInitialization(Object arg0, String arg1);
  public Object postProcessBeforeInitialization(Object arg0, String arg1).
还要在spring xml中配置:
	<!-- 配置 bean 后置处理器: 不需要配置 id 属性, IOC 容器会识别到他是一个 bean 后置处理器, 并调用其方法 -->
	<bean class="com.atguigu.spring.ref.MyBeanPostProcessor"></bean>

添加 Bean 后置处理器后 Bean 的生命周期

•Spring IOC 容器对 Bean 的生命周期进行管理的过程:

  –通过构造器或工厂方法创建 Bean 实例
  –为 Bean 的属性设置值和对其他 Bean 的引用
  –将 Bean 实例传递给 Bean 后置处理器的 postProcessBeforeInitialization 方法
  –调用 Bean 的初始化方法
  –将 Bean 实例传递给 Bean 后置处理器的 postProcessAfterInitialization方法
  –Bean 可以使用了
  –当容器关闭时, 调用 Bean 的销毁方法

通过调用静态工厂方法创建 Bean

•调用静态工厂方法创建 Bean是将对象创建的过程封装到静态方法中. 当客户端需要对象时, 只需要简单地调用静态方法, 而不同关心创建对象的细节.

•要声明通过静态方法创建的 Bean, 需要在 Bean 的 class 属性里指定拥有该工厂的方法的类, 同时在 factory-method 属性里指定工厂方法的名称. 最后, 使用 <constrctor-arg> 元素为该方法传递方法参数.

通过调用实例工厂方法创建 Bean

实例工厂方法: 将对象的创建过程封装到另外一个对象实例的方法里. 当客户端需要请求对象时, 只需要简单的调用该实例方法而不需要关心对象的创建细节.

•要声明通过实例工厂方法创建的 Bean

  –在 bean 的 factory-bean 属性里指定拥有该工厂方法的 Bean
  –在 factory-method 属性里指定该工厂方法的名称
  –使用 construtor-arg 元素为工厂方法传递方法参数

实现 FactoryBean 接口在 Spring IOC 容器中配置 Bean

•Spring 中有两种类型的 Bean, 一种是普通Bean, 另一种是工厂Bean, 即FactoryBean.

•工厂 Bean 跟普通Bean不同, 其返回的对象不是指定类的一个实例, 其返回的是该工厂 Bean 的 getObject 方法所返回的对象。实现FactoryBean 接口。
技术分享
 1     <!-- 通过工厂方法的方式来配置 bean -->
 2     <!-- 1. 通过静态工厂方法: 一个类中有一个静态方法, 可以返回一个类的实例(了解) -->
 3     <!-- 在 class 中指定静态工厂方法的全类名, 在 factory-method 中指定静态工厂方法的方法名 -->
 4     <bean id="dateFormat" class="java.text.DateFormat" factory-method="getDateInstance">
 5         <!-- 可以通过 constructor-arg 子节点为静态工厂方法指定参数 -->
 6         <constructor-arg value="2"></constructor-arg>
 7     </bean>
 8     
 9     <!-- 2. 实例工厂方法: 先需要创建工厂对象, 再调用工厂的非静态方法返回实例(了解) -->
10     <!-- ①. 创建工厂对应的 bean -->
11     <bean id="simpleDateFormat" class="java.text.SimpleDateFormat">
12         <constructor-arg value="yyyy-MM-dd hh:mm:ss"></constructor-arg>
13     </bean>
14     
15     <!-- ②. 有实例工厂方法来创建 bean 实例 -->
16     <!-- factory-bean 指向工厂 bean, factory-method 指定工厂方法(了解) -->
17     <bean id="datetime" factory-bean="simpleDateFormat" factory-method="parse">
18         <!-- 通过 constructor-arg 执行调用工厂方法需要传入的参数 -->
19         <constructor-arg value="1990-12-12 12:12:12"></constructor-arg>
20     </bean>
21     
22     <!-- 配置通过 FactroyBean 的方式来创建 bean 的实例(了解) -->
23     <bean id="user" class="com.atguigu.spring.ref.UserBean"></bean>
View Code

基于注解的方式配置Bean(基于注解配置 Bean;基于注解来装配 Bean 的属性)

在 classpath 中扫描组件

•组件扫描(component scanning):  Spring 能够从 classpath 下自动扫描, 侦测和实例化具有特定注解的组件.

•特定组件包括:

  –@Component: 基本注解, 标识了一个受 Spring 管理的组件
  –@Respository: 标识持久层组件
  –@Service: 标识服务层(业务层)组件
  –@Controller: 标识表现层组件

•对于扫描到的组件, Spring 有默认的命名策略: 使用非限定类名, 第一个字母小写. 也可以在注解中通过 value 属性值标识组件的名称

•当在组件类上使用了特定的注解之后, 还需要在 Spring 的配置文件中声明 <context:component-scan>

  –base-package 属性指定一个需要扫描的基类包,Spring 容器将会扫描这个基类包里及其子包中的所有类.
  –当需要扫描多个包时, 可以使用逗号分隔.
  –如果仅希望扫描特定的类而非基包下的所有类,可使用 resource-pattern 属性过滤特定的类,示例:
    技术分享
  –<context:include-filter> 子节点表示要包含的目标类
  –<context:exclude-filter> 子节点表示要排除在外的目标类
  –<context:component-scan> 下可以拥有若干个 <context:include-filter> 和 <context:exclude-filter> 子节点
•<context:include-filter> 和 <context:exclude-filter> 子节点支持多种类型的过滤表达式:
  技术分享

组件装配

•<context:component-scan> 元素还会自动注册 AutowiredAnnotationBeanPostProcessor 实例, 该实例可以自动装配具有 @Autowired 和 @Resource 、@Inject注解的属性.

使用 @Autowired 自动装配 Bean

•@Autowired 注解自动装配具有兼容类型的单个 Bean属性
  –构造器, 普通字段(即使是非 public), 一切具有参数的方法都可以应用@Authwired 注解
  –默认情况下, 所有使用 @Authwired 注解的属性都需要被设置. 当 Spring 找不到匹配的 Bean 装配属性时, 会抛出异常, 若某一属性允许不被设置, 可以设置 @Authwired 注解的 required 属性为 false
  –默认情况下, 当 IOC 容器里存在多个类型兼容的 Bean 时, 通过类型的自动装配将无法工作. 此时可以在 @Qualifier 注解里提供 Bean 的名称. Spring 允许对方法的入参标注 @Qualifiter 已指定注入 Bean 的名称
  – @Authwired 注解也可以应用在数组类型的属性上, 此时 Spring 将会把所有匹配的 Bean 进行自动装配.
  –@Authwired 注解也可以应用在集合属性上, 此时 Spring 读取该集合的类型信息, 然后自动装配所有与之兼容的 Bean.
  –@Authwired 注解用在 java.util.Map 上时, 若该 Map 的键值为 String, 那么 Spring 将自动装配与之 Map 值类型兼容的 Bean, 此时 Bean 的名称作为键值

使用 @Resource 或 @Inject自动装配 Bean

•Spring 还支持 @Resource 和 @Inject 注解,这两个注解和 @Autowired 注解的功用类似
@Resource 注解要求提供一个 Bean 名称的属性,若该属性为空,则自动采用标注处的变量或方法名作为 Bean 的名称
•@Inject 和 @Autowired 注解一样也是按类型匹配注入的 Bean, 但没有 reqired 属性
建议使用 @Autowired 注解

泛型依赖注入

•Spring 4.x 中可以为子类注入子类对应的泛型类型的成员变量的引用
  技术分享

整合多个配置文件

•Spring 允许通过 <import> 将多个配置文件引入到一个文件中,进行配置文件的集成。这样在启动 Spring 容器时,仅需要指定这个合并好的配置文件就可以。

•import 元素的 resource 属性支持 Spring 的标准的路径资源

技术分享

Spring Bean配置2

标签:

原文地址:http://www.cnblogs.com/linyueshan/p/5831615.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!