您的位置:首页 > 编程语言 > Java开发

Spring自动注入Bean

2011-03-04 14:54 295 查看
通过@Autowired或@Resource来实现在Bean中自动注入的功能,但还要在配置文件中写Bean定义,下面我们将介绍如何注解Bean,从而从XML配置文件
中完全移除Bean定义的配置。

1. @Component(不推荐使用)、@Repository、@Service、@Controller

只需要在对应的类上加上一个@Component注解,就将该类定义为一个Bean了:

Java
代码

@Component

public

class

UserDaoImpl

extends

HibernateDaoSupport

implements

UserDao {

...

}

@Component
public class UserDaoImpl extends HibernateDaoSupport implements UserDao {
...
}


使用@Component注解定义的Bean,默认的名称(id)是小写开头的非限定类名。如这里定义的Bean名称就是
userDaoImpl。你也可以指定Bean的名称:

@Component("userDao")

@Component是所有受Spring管理组件的通用形式,Spring还提供了更加细化的注解形式:@Repository、
@Service、@Controller,它们分别对应存储层Bean,业务层Bean,和展示层Bean。目前版本(2.5)中,这些注解与
@Component的语义是一样的,完全通用,在Spring以后的版本中可能会给它们追加更多的语义。所以,我们推荐使用@Repository、
@Service、@Controller来替代@Component。

2. 使用<context:component-scan />让Bean定义注解工作起来

Java
代码

<beans xmlns=

"http://www.springframework.org/schema/beans"

xmlns:xsi=

"http://www.w3.org/2001/XMLSchema-instance"

xmlns:context=

"http://www.springframework.org/schema/context"

xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<context:component-scan base-package

=

"com.kedacom.ksoa"

/>

</beans>

<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd"> <context:component-scan base-package="com.kedacom.ksoa" />
</beans>


这里,所有通过<bean>元素定义Bean的配置内容已经被移除,仅需要添加一行<context:component-
scan />配置就解决所有问题了——Spring
XML配置文件得到了极致的简化(当然配置元数据还是需要的,只不过以注释形式存在罢了)。<context:component-scan
/>的base-package属性指定了需要扫描的类包,类包及其递归子包中所有的类都会被处理。

<context:component-scan
/>还允许定义过滤器将基包下的某些类纳入或排除。Spring支持以下4种类型的过滤方式:

过滤器类型 表达式范例 说明

注解 org.example.SomeAnnotation 将所有使用SomeAnnotation注解的类过滤出来

类名指定 org.example.SomeClass 过滤指定的类

正则表达式 com/.kedacom/.spring/.annotation/.web/..* 通过正则表达式过滤一些类

AspectJ表达式 org.example..*Service+ 通过AspectJ表达式过滤一些类

以正则表达式为例,我列举一个应用实例:

Java
代码

<context:component-scan base-

package

=

"com.casheen.spring.annotation"

>

<context:exclude-filter type="regex"

expression=

"com/.casheen/.spring/.annotation/.web/..*"

/>

</context:component-scan>

<context:component-scan base-package="com.casheen.spring.annotation">
<context:exclude-filter type="regex" expression="com/.casheen/.spring/.annotation/.web/..*" />
</context:component-scan>


值得注意的是<context:component-scan
/>配置项不但启用了对类包进行扫描以实施注释驱动Bean定义的功能,同时还启用了注释驱动自动注入的功能(即还隐式地在内部注册了
AutowiredAnnotationBeanPostProcessor和CommonAnnotationBeanPostProcessor),
因此当使用<context:component-scan />后,就可以将<context:annotation-config
/>移除了。

3. 使用@Scope来定义Bean的作用范围

在使用XML定义Bean时,我们可能还需要通过bean的scope属性来定义一个Bean的作用范围,我们同样可以通过@Scope注解来完
成这项工作:

Java
代码

@Scope

(

"session"

)

@Component

()

public

class

UserSessionBean

implements

Serializable {

...

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: