Annotation(三)——Spring注解开发

      Spring框架的核心功能IoC(Inversion of Control),也就是通过Spring容器进行对象的管理,以及对象之间组合关系的映射。通常情况下我们会在xml配置文件中进行action,service,dao等层的声明,然后并告知框架我们想要的注入方式,然后在类中声明要组合类的getset方法。而通过Spring框架中注解的运用也就主要是解决这类问题的。而框架中另一个核心知识AOP,一种面向横切面的方法编程,在程序中一般都是进行一次设置就可以的,所以都还放在配置文件中。例如声明式事物的设置,一次设置,后边我就不用管了,所以这个没有必要使用注解进行简化。因为工作量都差不多。好了,看一下在Spring中如何使用注解进行开发吧!

 

           一,首先需要在配置文件中增加命名空间的和约束文件:

  1. <beans ...  
  2.         xmlns:context="http://www.springframework.org/schema/context"  
  3.     xsi:schemaLocation="  
  4.         ...  
  5.         http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd  
  6.         ">  

         二,开启Spring的注解功能,这样Spring环境才会进行指定位置的扫描,进行类之间的关联组合:

  1. <!-- 扫描注解类  
  2.     base-package : 表示当前扫描的包,框架会根据包查找所有使用注解的类  
  3.  -->  
  4. <context:component-scan base-package="com.ljh.spring.*" />  

         三,声明注解类,让Spring框架可以识别:

            1,类的分层注解,由于我们后台开发都是分为三层进行开发的,所以Spring框架提供了三种对于不同层的注解方式:

               控制层:@Controller

               服务层:@Service

               持久层:@Repository

 

            类似于我们配置文件中的:

  1. <bean id="orgService" class="com.ljh.web.Service.OrgService"></bean>  

         默认情况下使用注解声明的Bean对象id名称为:类名称的首字母小写,一般不需要我们进行设置,如果想要设置时,例如我们指定的是实现类,而名字指向了接口,直接添加value属性即可:@Service(value="name"),当然value是可以省略的。

 

           Spring框架还为我们提供了代替上边三个分层注解的通用注解:@Component.当然提倡大家使用分层注解更好一些,区分层次比较明确。

 

          2,自动装配功能的实现对象之间的组合关系,在属性前边指定下边的注解:

              @Autowired : 采用类型的方式完成自动装配 : byType

              @Resource : 采用名称+类型的方式完成自动装配 : byName +byType,此种方法推荐使用。

             另外Spring提供的两种注解的自动装配功能,属性不需要声明set,get方法也可以完成组合功能,这是非常方便的。

 

          3,在声明action时,需要指定其为多例的,解决线程安全的问题,在配置文件中我们通常会这样声明action的类:

  1. <bean id="orgAction" class="com.ljh.web.action.OrgAction" scope="prototype"></bean>  

          而在Spring注解开发中也提供了类似的属性来解决此问题,在action类前边设定如下:

 @Scope("prototype")

 

         4,利用配置文件声明Dao层类时,通常是这样的:

  1. <!-- dao层需要引用我们的sessionFactory工厂,自动装配时,  
  2.         是会自动装配名叫sessionFactory的工厂,所以可以省略。   
  3.     -->  
  4.     <bean name ="orgTypeDao" class="com.ljh.dao.impl.OrgTypeDaoImpl">  
  5.         <!--<property name="sessionFactory" ref="sessionFactory"></property>-->  
  6.     </bean>  

           而,注解开发的方法如何进行sessionFactory的注入呢?由于Dao层继承了父类HibernateDaoSupport,而在父类中有这样一个方法:

  1.       //父类中的sessionFactory的set注入方法  
  2. ublic final void setSessionFactory(SessionFactory sessionFactory) {  
  3. if (this.hibernateTemplate == null || sessionFactory != this.hibernateTemplate.getSessionFactory()) {  
  4.     this.hibernateTemplate = createHibernateTemplate(sessionFactory);  
  5. }  

          这是sessionFactoryset注入方法,所以如果我们能够重写此方法,在此方法上进行@Resource注解,即可解决我们的问题,但是可以看到此方法是用final进行修饰的,所以通常情况下,我们采用下边的这种方法进行解决:

  1. @Repository("orgDao")  
  2. public class OrgDaoImpl extends HibernateDaoSupport implements OrgDao {  
  3.   
  4.     @Resource  
  5.     //自定义了方法,解决了父类中final修饰不能重写的问题  
  6.     public void setSuperSessionFactory(SessionFactory sessionFactory) {  
  7.              //调用了父类的setSessionFactory方法  
  8.         super.setSessionFactory(sessionFactory);  
  9.     }  
  10. }  

           这样,Dao层的sessionFactory就进行了注入,我们可以正常编写我们的Dao层代码了。当然了对于Dao层如果我们使用了Ibatis,同样可以使用这种方法进行Ibatis核心对象sqlMapClient的注入。

 

          综上,为Spring框架的注解开发常用注解,总体感觉还是比较简单,最起码相对其它两个框架而言,主要是通过注解完成对象的管理,和对象之间的组合,即SpringIoC功能。注解的开发还是能大大提高我们的开发效率的,但是还是那句话,它在一定程度上违背了OCP原则,所以大力推荐使用注解的开发的前提还是我们的需求比较固定,变动较小。


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。