zoukankan      html  css  js  c++  java
  • spring声明式事务配置方法(六):aop:config切入 摘自:百度空间

    1. <?xml version="1.0" encoding="UTF-8"?>  
    2.   
    3. <beans xmlns="http://www.springframework.org/schema/beans"  
    4.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
    5.     xmlns:aop="http://www.springframework.org/schema/aop"  
    6.     xmlns:tx="http://www.springframework.org/schema/tx"  
    7.     xsi:schemaLocation="   
    8.              http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
    9.              http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd   
    10.              http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">  
    11.     <bean id="testAction" class="test.action.Stuts2ActionTest">  
    12.         <property name="service" ref="templatesService"></property>  
    13.     </bean>  
    14.   
    15.     <bean id="templatesService"  
    16.         class="test.service.impl.TaoTemplatesServiceImpl">  
    17.         <property name="dao" ref="templatesDAO" />  
    18.     </bean>  
    19.   
    20.     <bean id="templatesDAO" class="test.dao.impl.TaoTemplatesDAOImpl">  
    21.         <property name="sessionFactory" ref="sessionFactory"></property>  
    22.     </bean>  
    23.   
    24.   
    25.     <!--定义数据源-->  
    26.     <bean id="dataSource"  
    27.         class="org.apache.commons.dbcp.BasicDataSource">  
    28.         <!--    定义数据库驱动-->  
    29.         <property name="driverClassName">  
    30.             <value>oracle.jdbc.driver.OracleDriver</value>  
    31.         </property>  
    32.         <!--    定义数据库url-->  
    33.         <property name="url">  
    34.             <value>jdbc:oracle:thin:@192.168.1.96:1521:yxdb</value>  
    35.         </property>  
    36.         <!--    定义数据库用户名-->  
    37.         <property name="username">  
    38.             <value>yxuser</value>  
    39.         </property>  
    40.         <!--    定义数据库密码-->  
    41.         <property name="password">  
    42.             <value>yxuser</value>  
    43.         </property>  
    44.     </bean>  
    45.   
    46.     <!--定义一个hibernate的SessionFactory-->  
    47.     <bean id="sessionFactory"  
    48.         class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
    49.         <!--    定义SessionFactory必须注入DataSource-->  
    50.         <property name="dataSource">  
    51.             <ref local="dataSource" />  
    52.         </property>  
    53.         <property name="mappingResources">  
    54.             <list>  
    55.                 <!--以下用来列出所有的PO映射文件-->  
    56.                 <value>test/mapping/Tao_Templates.hbm.xml</value>  
    57.             </list>  
    58.         </property>  
    59.         <property name="hibernateProperties">  
    60.             <props>  
    61.                 <prop key="hibernate.dialect">  
    62.                      org.hibernate.dialect.Oracle10gDialect   
    63.                 </prop>  
    64.                 <prop key="hibernate.show_sql">true</prop>  
    65.                  <!--此处用来定义hibernate的SessionFactory的属性:   
    66.                      不同数据库连接,启动时选择create,update,create-drop -->  
    67.                 <prop key="hibernate.hbm2ddl.auto">update</prop>  
    68.             </props>  
    69.         </property>  
    70.     </bean>  
    71.   
    72.     <bean id="transactionManager"  
    73.         class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
    74.         <property name="sessionFactory">  
    75.             <ref bean="sessionFactory" />  
    76.         </property>  
    77.     </bean>   
    78.  1 <!--
       2 <bean id="transactionManager"
       3         class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
       4         <property name="dataSource" ref="jamon-proxy-DataSource"></property>
       5     </bean>
       6 -->
       7 <!-- 事务通知 -->   
       8     <tx:advice id="txAdvice" transaction-manager="transactionManager">   
       9         <tx:attributes>   
      10             <tx:method name="add*" propagation="REQUIRED" rollback-for="Exception,SmoException,BmoException,DaoException" />   
      11             <tx:method name="del*" propagation="REQUIRED" rollback-for="Exception,SmoException,BmoException,DaoException" />   
      12             <tx:method name="upd*" propagation="REQUIRED" rollback-for="Exception,SmoException,BmoException,DaoException" />
      13    <tx:method name="*" propagation="SUPPORTS" read-only="true" />
      14   </tx:attributes>
      15  </tx:advice>
      16  <!-- Spring AOP config 
      17  解释一下(* com.evan.crm.service.*.*(..))中几个通配符的含义:
      18  第一个 * —— 通配 任意返回值类型
      19  第二个 * —— 通配 包com.evan.crm.service下的任意class
      20  第三个 * —— 通配 包com.evan.crm.service下的任意class的任意方法
      21  第四个 .. —— 通配 方法可以有0个或多个参数
      22   -->
      23  <aop:config>
      24   <aop:pointcut id="servicesPointcut" expression="execution(* com.jstrd.mss..*SMOImpl.*(..))" />
      25   <aop:advisor advice-ref="bluePrint.txAdvice" pointcut-ref="servicesPointcut" />  
      26  </aop:config>   
      27 
      28 </beans>   
      29 
      30 
  • 相关阅读:
    Appium简介
    本章小结
    测试角色定位,岗位职责
    如何做好空降管理者
    如何把控产品质量
    Appium自动化测试教程-自学网-monkeyrunner API
    Appium自动化测试教程-自学网-monkeyrunner简介
    Appium自动化测试教程-自学网-monkey日志管理
    Appium自动化测试教程-自学网-monkey自定义脚本实践
    Appium自动化测试教程-自学网-monkey参数
  • 原文地址:https://www.cnblogs.com/ding0910/p/1882061.html
Copyright © 2011-2022 走看看