200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > Java程序员从笨鸟到菜鸟之(七十二)细谈Spring(四)利用注解实现spring基本配置详解

Java程序员从笨鸟到菜鸟之(七十二)细谈Spring(四)利用注解实现spring基本配置详解

时间:2021-12-23 06:03:35

相关推荐

Java程序员从笨鸟到菜鸟之(七十二)细谈Spring(四)利用注解实现spring基本配置详解

注:由于本人不大习惯注解方式,所以讲解完这里的注解实现基本配置之后,以后就不再单独把注解拿出来讲解了。

五:spring注解

1.准备工作

(1)导入common-annotations.jar

(2)导入schema文件文件名为spring-context-2.5.xsd

(3)在xml的beans节点中配置

2.xml配置工作

[html]view plaincopy print? <?xmlversion="1.0"encoding="UTF-8"?> <beansxmlns="/schema/beans" xmlns:xsi="/2001/XMLSchema-instance" xmlns:context="/schema/context" xsi:schemaLocation="/schema/beans /schema/beans/spring-beans-2.5.xsd /schema/context /schema/context/spring-context-2.5.xsd" default-default-lazy-init="true"> <!--将针对注解的处理器配置好--> <context:annotation-config/> <!--使用annotation定义事务--> <tx:annotation-driventransaction-managertx:annotation-driventransaction-manager="transactionManager"proxy-target-class="true"/> <!--使用annotation自动注册bean,并检查@Required,@Autowired的属性已被注入base-package为需要扫描的包(含所有子包)--> <context:component-scanbase-packagecontext:component-scanbase-package="com"/> ..... <beans>

注:<context:component-scanbase-package="*.*"/>

该配置隐式注册了多个对注解进行解析的处理器,如:

AutowiredAnnotationBeanPostProcessor

CommonAnnotationBeanPostProcessor

PersistenceAnnotationBeanPostProcessor

RequiredAnnotationBeanPostProcessor

其实,注解本身做不了任何事情,和XML一样,只起到配置的作用,主要在于背后强大的处理器,其中就包括了<context:annotation-config/>配置项里面的注解所使用的处理器,所以配置了<context:component-scanbase-package="">之后,便无需再配置<context:annotation-config>

1.在Java代码中使用@Autowired或@Resource注解方式进行装配,这两个注解的区别是:@Autowired默认按类型装配,@Resource默认按名称装配,当找不到名称匹配的bean才会按类型装配。

@Autowired一般装配在set方法之上,也可以装配在属性上边,但是在属性上边配置,破坏了java的封装,所以一般不建议使用

@Autowired是根据类型进行自动装配的。如果当Spring上下文中存在不止一个所要装配类型的bean时,就会抛出BeanCreationException异常;如果Spring上下文中不存在所要装配类型的bean,也会抛出BeanCreationException异常。我们可以使用@Qualifier配合@Autowired来解决这些问题。

[java]view plaincopy print? @Autowired publicvoidsetUserDao(@Qualifier("userDao")UserDaouserDao){ this.userDao=userDao; }

这样,Spring会找到id为userDao的bean进行装配。

可能不存在UserDao实例

[java]view plaincopy print? @Autowired(required=false) publicvoidsetUserDao(UserDaouserDao){ this.userDao=userDao; }

2.@Resource(JSR-250标准注解,推荐使用它来代替Spring专有的@Autowired注解)Spring不但支持自己定义的@Autowired注解,还支持几个由JSR-250规范定义的注解,它们分别是@Resource、@PostConstruct以及@PreDestroy。

@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按byName自动注入罢了。@Resource有两个属性是比较重要的,分别是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略

@Resource装配顺序

1如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常

2如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常

3如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常

4如果既没有指定name,又没有指定type,则自动按照byName方式进行装配(见2);如果没有匹配,则回退为一个原始类型(UserDao)进行匹配,如果匹配则自动装配;

3.@PostConstruct(JSR-250)

在方法上加上注解@PostConstruct,这个方法就会在Bean初始化之后被Spring容器执行(注:Bean初始化包括,实例化Bean,并装配Bean的属性(依赖注入))。

它的一个典型的应用场景是,当你需要往Bean里注入一个其父类中定义的属性,而你又无法复写父类的属性或属性的setter方法时,如:

[java]view plaincopy print? publicclassUserDaoImplextendsHibernateDaoSupportimplementsUserDao{ privateSessionFactorymySessionFacotry; @Resource publicvoidsetMySessionFacotry(SessionFactorysessionFacotry){ this.mySessionFacotry=sessionFacotry; } @PostConstruct publicvoidinjectSessionFactory(){ super.setSessionFactory(mySessionFacotry); }}

这里通过@PostConstruct,为UserDaoImpl的父类里定义的一个sessionFactory私有属性,注入了我们自己定义的sessionFactory(父类的setSessionFactory方法为final,不可复写),之后我们就可以通过调用super.getSessionFactory()来访问该属性了。

4.@PreDestroy(JSR-250)

在方法上加上注解@PreDestroy,这个方法就会在Bean初始化之后被Spring容器执行。由于我们当前还没有需要用到它的场景,这里不不去演示。其用法同@PostConstruct。

5.使用Spring注解完成Bean的定义

以上我们介绍了通过@Autowired或@Resource来实现在Bean中自动注入的功能,下面我们将介绍如何注解Bean,从而从XML配置文件中完全移除Bean定义的配置。

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

[java]view plaincopy print? @Component publicclassUserDaoImplextendsHibernateDaoSupportimplementsUserDao{ ... }

使用@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。

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

[html]view plaincopy print? <prename="code"class="html"><beansxmlns="/schema/beans" xmlns:xsi="/2001/XMLSchema-instance" xmlns:context="/schema/context" xsi:schemaLocation="/schema/beans /schema/beans/spring-beans-2.5.xsd /schema/context /schema/context/spring-context-2.5.xsd"> <context:component-scanbase-package="com.bzu"/> </beans></pre><br> <br> <pre></pre> <br> <br> <p></p> <pstyle="background:rgb(250,250,250)"><spanstyle="font-size:18px">这里,所有通过<spanstyle="font-family:TimesNewRoman"><bean></span><spanstyle="font-family:宋体">元素定义</span><spanstyle="font-family:TimesNewRoman">Bean</span><spanstyle="font-family:宋体">的配置内容已经被移除,仅需要添加一行</span><spanstyle="font-family:TimesNewRoman"><context:component-scan/></span><spanstyle="font-family:宋体">配置就解决所有问题了</span><spanstyle="font-family:TimesNewRoman">——SpringXML</span><spanstyle="font-family:宋体">配置文件得到了极致的简化(当然配置元数据还是需要的,只不过以注释形式存在罢了)。</span><spanstyle="font-family:TimesNewRoman"><context:component-scan/></span><spanstyle="font-family:宋体">的</span><spanstyle="font-family:TimesNewRoman">base-package</span><spanstyle="font-family:宋体">属性指定了需要扫描的类包,类包及其递归子包中所有的类都会被处理。</span><br> <context:component-scan/><spanstyle="font-family:宋体">还允许定义过滤器将基包下的某些类纳入或排除。</span><spanstyle="font-family:TimesNewRoman">Spring</span><spanstyle="font-family:宋体">支持以下</span><spanstyle="font-family:TimesNewRoman">4</span><spanstyle="font-family:宋体">种类型的过滤方式:</span></span></p> <pstyle="background:rgb(239,239,239)"><spanstyle="font-size:18px">·过滤器类型表达式范例说明</span></p> <pstyle="background:rgb(239,239,239)"><spanstyle="font-size:18px">·注解<spanstyle="font-family:Helvetica">org.example.SomeAnnotation</span><spanstyle="font-family:宋体">将所有使用</span><spanstyle="font-family:Helvetica">SomeAnnotation</span><spanstyle="font-family:宋体">注解的类过滤出来</span></span></p> <pstyle="background:rgb(239,239,239)"><spanstyle="font-size:18px">·类名指定<spanstyle="font-family:Helvetica">org.example.SomeClass</span><spanstyle="font-family:宋体">过滤指定的类</span></span></p> <pstyle="background:rgb(239,239,239)"><spanstyle="font-size:18px">·正则表达式<spanstyle="font-family:Helvetica">com\.kedacom\.spring\.annotation\.web\..*</span><spanstyle="font-family:宋体">通过正则表达式过滤一些类</span></span></p> <pstyle="background:rgb(239,239,239)"><spanstyle="font-size:18px">·AspectJ<spanstyle="font-family:宋体">表达式</span><spanstyle="font-family:Helvetica">org.example..*Service+</span><spanstyle="font-family:宋体">通过</span><spanstyle="font-family:Helvetica">AspectJ</span><spanstyle="font-family:宋体">表达式过滤一些类</span></span></p> <p><spanstyle="font-size:18px"><spanstyle="color:rgb(0,0,255)">7.</span><spanstyle="color:rgb(0,0,255)">使用<spanstyle="font-family:TimesNewRoman">@Scope</span><spanstyle="font-family:宋体">来定义</span><spanstyle="font-family:TimesNewRoman">Bean</span><spanstyle="font-family:宋体">的作用范围</span></span><br> 在使用<spanstyle="font-family:TimesNewRoman">XML</span><spanstyle="font-family:宋体">定义</span><spanstyle="font-family:TimesNewRoman">Bean</span><spanstyle="font-family:宋体">时,我们可能还需要通过</span><spanstyle="font-family:TimesNewRoman">bean</span><spanstyle="font-family:宋体">的</span><spanstyle="font-family:TimesNewRoman">scope</span><spanstyle="font-family:宋体">属性来定义一个</span><spanstyle="font-family:TimesNewRoman">Bean</span><spanstyle="font-family:宋体">的作用范围,我们同样可以通过</span><spanstyle="font-family:TimesNewRoman">@Scope</span><spanstyle="font-family:宋体">注解来完成这项工作:</span></span></p> <pstyle="background:rgb(250,250,250)"><spanstyle="font-size:18px"></span></p> <prename="code"class="java">@Scope("session") @Component() publicclassUserSessionBeanimplementsSerializable{ ... }</pre> <p></p> <pstyle="background:rgb(250,250,250)"><spanstyle="font-size:18px"><br> <br> <br> <br> <br> <br> </span></p> <p></p> from:/csh624366188/article/details/7647815

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。