• ApplicationContext.xml文件详解


    想必用过Spring的程序员们都有这样的感觉,Spring把逻辑层封装的太完美了(个人感觉View层封装的不是很好)。以至于有的初学者都不知道Spring配置文件的意思,就拿来用了。所以今天我给大家详细解释一下Spring的applicationContext.xml文件。Ok,还是通过代码加注释的方式为大家演示:

    以下是详解Spring的applicationContext.xml文件代码:
    <!-- 头文件,主要注意一下编码 -->

    1. <?xml version="1.0" encoding="UTF-8"?>  
    2. <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN""http://www.springframework.org/dtd/spring-beans.dtd">  
    3. <beans>  


     


    <!-- 建立数据源 -->

    1. <bean id="dataSource"class="org.apache.commons.dbcp.BasicDataSource">  

     

      <!-- 数据库驱动,我这里使用的是Mysql数据库 -->
      

    1. <propertynamepropertyname="driverClassName">  
    2.     <value>com.mysql.jdbc.Driver</value>  
    3.    </property>  



      <!-- 数据库地址,这里也要注意一下编码,不然乱码可是很郁闷的哦! -->

    1. <property name="url">  
    2.     <value>  
    3.       jdbc:mysql://localhost:3306/tie?useUnicode=true&characterEncoding=utf-8  
    4.    </value>  
    5.    </property>  


      

      <!-- 数据库的用户名 -->
       

    1. <property name="username">  
    2.     <value>root</value>  
    3.    </property>  


     

      <!-- 数据库的密码 -->
      

    1. <property name="password">  
    2.     <value>123</value>  
    3.    </property>  
    4. </bean>  


     

    <!-- 把数据源注入给Session工厂 -->

    1. <bean id="sessionFactory"  
    2.   class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
    3.    <property name="dataSource">  
    4.     <ref bean="dataSource" />  
    5.    </property>  


     

      <!-- 配置映射文件 -->
      

    1. <property name="mappingResources">  
    2.     <list>  
    3.      <value>com/alonely/vo/User.hbm.xml</value>  
    4.     </list>  
    5.    </property>  
    6. </bean>  


     

    <!-- 把Session工厂注入给hibernateTemplate -->
    <!-- 解释一下hibernateTemplate:hibernateTemplate提供了很多方便的方法,在执行时自动建立 HibernateCallback 对象,例如:load()、get()、save、delete()等方法。 -->

    1. <bean id="hibernateTemplate"  
    2.   class="org.springframework.orm.hibernate3.HibernateTemplate">  
    3.    <constructor-arg>  
    4.     <ref local="sessionFactory" />  
    5.    </constructor-arg>  
    6. </bean>  


     

    <!-- 把DAO注入给Session工厂 -->

    1. <bean id="userDAO" class="com.alonely.dao.UserDAO">  
    2.    <property name="sessionFactory">  
    3.     <ref bean="sessionFactory" />  
    4.    </property>  
    5. </bean>  


     

    <!-- 把Service注入给DAO -->

    1. <bean id="userService"class="com.alonely.service.UserService">  
    2.    <property name="userDAO">  
    3.     <ref local="userDAO" />  
    4.    </property>  
    5. </bean>  


     

    <!-- 把Action注入给Service -->

    1. <bean name="/user"class="com.alonely.struts.action.UserAction">  
    2.    <property name="userService">  
    3.     <ref bean="userService" />  
    4.    </property>  
    5. </bean>  
    6. </beans>  


     

    以上Spring的applicationContext.xml文件我是用的SSH架构,如果您用Spring的MVC架构,其原理也是一样的。

    对里面的一些概念还不熟悉,一个字"晕"啊,在网上搜搜资料,解释一下applicationcontext.xml

    我们以项目中的订单Order为例简要说明一下Spring与Hibernate的集成。关于如何使用Hibernate来对数据库表做映射,我们在前面已经做了介绍,这里我们关心的是如何配置Spring,使它能管理Hibernate。其实,只要在Spring的配置文件(我们这里是applicationContext.xml)中配置一个叫做sessionFactory的bean,Spring就可以和Hibernate联系起来了。

    1. <beanidbeanid="sessionFactory" class="org.springframework.orm.hibernate.LocalSessionFactoryBean">  
    2.   
    3.    <property name="configLocation">  
    4.   
    5.    <value>com/ascent/bean/hibernate.cfg.xml</value>  
    6.   
    7.    </property>  
    8.   
    9. </bean>  


     

    这样,Spring和Hibernate的第一步整合就完成了,现在到了关键的地方——如何让Spring和Hibernate双剑合璧来实现业务逻辑?

    还是在applicationContext.xml文件中先做一个配置。

    1. <beanidbeanid="transactionManager"class="org.springframework.orm.hibernate.HibernateTransactionManager">  
    2.   
    3.    <property name="sessionFactory">  
    4.   
    5.      <ref local="sessionFactory"/>  
    6.   
    7.    </property>  
    8.   
    9.   </bean>  


     

    在上面你大概可以感觉到Spring给我们带来的好处了,Spring的IoC模式可以统一管理各层,而又使各层松散耦合在一起,使各层之间实现最大的解耦性,这也是Web架构一向的追求。

    但是,Spring带来的好处还不止于此,除了IoC还有AOP,Spring可以运用AOP来实现很多功能,最常用的就是事务处理。这里我们用了业务服务(business service)层和数据存取对象(Data Access Object)层,在业务服务层我们增加事务处理,数据存取对象层负责数据读写。

    首先,组装配置好Service Beans。

    1. <beanidbeanid="orderService" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">  
    2.   
    3.    <property name="transactionManager">  
    4.   
    5.      <ref local="transactionManager"/>  
    6.   
    7.    </property>  
    8.   
    9.    <property name="target">  
    10.   
    11.      <ref local="orderTarget"/>  
    12.   
    13.    </property>  
    14.   
    15.    <property name="transactionAttributes">  
    16.   
    17.      <props>  
    18.   
    19.         <propkeypropkey="find*">PROPAGATION_REQUIRED,readOnly,-OrderException</prop>  
    20.   
    21.        <propkeypropkey="save*">PROPAGATION_REQUIRED,-OrderException,-OrderMinimumAmountException</prop>  
    22.   
    23.      </props>  
    24.   
    25.    </property>  
    26.   
    27.   </bean>  


     

    之后,需要把业务服务对象和数据存取对象也组装起来,并把这些对象配到一个事务管理器(transaction manager)里。

    在Spring中的配置信息。

    1. <beanidbeanid="orderTarget"class="com.ascent.business.service.OrderServiceImpl">  
    2.   
    3.    <property name="orderDAO">  
    4.   
    5.      <ref local="orderDAO"/>  
    6.   
    7.    </property>  
    8.   
    9.   </bean>  
    10.   
    11.    
    12.   
    13. <beanidbeanid="orderDAO"class="com.ascent.dao.hibernate.OrderHibernateDAO">  
    14.   
    15.    <property name="sessionFactory">  
    16.   
    17.      <ref local="sessionFactory"/>  
    18.   
    19.    </property>  
    20.   
    21.   </bean>  


     

    每个对象都联系着Spring,并且能通过Spring注入到其他对象。把它与Spring的配置文件比较,观察他们之间的关系。

    Spring就是这样基于配置文件,将各个Bean搭建在一起的。

    这里我们使用一个TransactionProxyFactoryBean,它定义了一个setTransactionManager(),这个对象很有用,它能很方便地处理你申明的Service Object中的事物,你可以通过transaction Attributes属性来定义怎样处理。

    TransactionProxyFactoryBean还有个setter,这会被业务服务对象(orderTarget)引用,orderTarget定义了业务服务层,并且它还有个属性,由setOrderDAO()引用这个属性。

    还有一点要注意,bean可以用两种方式创造,这些都在单例模式(Sington)和原型模式(propotype)中定义了。默认的方式是singleton,这意味着共享的实例将被束缚,而原型模式是在Spring用到bean的时候允许新建实例的。当每个用户需要得到他们自己Bean的Copy时,你应该仅使用prototype模式。

     

    这样,Spring和Hibernate就完成了对业务对象的管理。

  • 相关阅读:
    使用.NET Core在RESTful API中进行路由操作
    基础教程:ASP.NET Core 2.0 MVC筛选器
    Angular 5和ASP.NET Core入门
    net core 使用tagHelper将 enum枚举类型转换为下拉列表select
    教你如何实现微信小程序与.net core应用服务端的无状态身份验证
    解决mssql localdb 中文乱码问题
    datagrid 新增,并行内编辑,提交保存
    合法的json数组字符串,转换json
    jfinal的回滚
    oracle 修改 字段名称
  • 原文地址:https://www.cnblogs.com/ning-blogs/p/4530905.html
Copyright © 2020-2023  润新知