Spring事务管理+AOP实现银行转账功能

使用xml版+注解版(已注掉)配置实现

第一步 建库建表

java银行卡强制扣款方案 java银行转账_经验分享

第二步 创建Dao层接口及其实现类

在Dao层实现两个方法,一个是转出的方法,一个是转入的方法,有个共同点,就是都要知道是谁转的帐(id),转了多少钱(money),在转出的同时,要转入相同的钱数

/**@文件名: BankTransferMoneyDao.java
 * @类功能说明: 银行转账Dao层接口
 * @作者: LiYuHui
 * @Email: 1327711913@qq.com
 * @日期: 2020年6月22日下午4:56:55
 * @修改说明:<br> 
 * <pre>
 * 	 <li>作者: LiYuHui</li> 
 * 	 <li>日期: 2020年6月22日下午4:56:55</li> 
 *	 <li>内容: </li>
 * </pre>
 */
public interface BankTransferMoneyDao {
	/**
	 * @方法名: outMoney
	 * @方法说明: 转出
	 * @作者: LiYuHui
	 * @邮箱:1327711913@qq.com
	 * @日期: 2020年6月22日下午5:18:01
	 * @param money
	 * @param user_id
	 * @return: void
	 */
	public void outMoney(double money,int user_id);
	
	/**
	 * @方法名: inMoney
	 * @方法说明: 转入
	 * @作者: LiYuHui
	 * @邮箱:1327711913@qq.com
	 * @日期: 2020年6月22日下午5:18:49
	 * @param money
	 * @param user_id
	 * @return: void
	 */
	public void inMoney(double money,int user_id);
}
/**@文件名: BankTransferMoneyDaoImpl.java
 * @类功能说明: 银行转账的Dao层接口的实现类
 * @作者: LiYuHui
 * @Email: 1327711913@qq.com
 * @日期: 2020年6月22日下午5:20:11
 * @修改说明:<br> 
 * <pre>
 * 	 <li>作者: LiYuHui</li> 
 * 	 <li>日期: 2020年6月22日下午5:20:11</li> 
 *	 <li>内容: </li>
 * </pre>
 */
public class BankTransferMoneyDaoImpl implements BankTransferMoneyDao {

	//注入带参数的JDBC模板
	private NamedParameterJdbcTemplate namedParameterJdbcTemplate;
	
	public void setNamedParameterJdbcTemplate(NamedParameterJdbcTemplate namedParameterJdbcTemplate) {
		this.namedParameterJdbcTemplate = namedParameterJdbcTemplate;
	}

	/**
	 * 转出
	 */
	@Override
	public void outMoney(double money, int user_id) {
		String sql = "update t_count set money=money-:money where user_id=:id";
		MapSqlParameterSource msps = new MapSqlParameterSource();
		msps.addValue("money", money);
		msps.addValue("id", user_id);
		namedParameterJdbcTemplate.update(sql, msps);
	}

	/**
	 * 转入
	 */
	@Override
	public void inMoney(double money, int user_id) {
		String sql = "update t_count set money=money+:money where user_id=:id";
		MapSqlParameterSource msps = new MapSqlParameterSource();
		msps.addValue("money", money);
		msps.addValue("id", user_id);
		namedParameterJdbcTemplate.update(sql, msps);
	}
}

第三步 创建Service接口及其实现类

Service层是处理业务逻辑的,在该层完成转账操作,转账需要知道:1、要转的钱数,2、谁转的钱,3、要转给谁

/**@文件名: BankTransferMoneyService.java
 * @类功能说明: 银行转账的service接口
 * @作者: LiYuHui
 * @Email: 1327711913@qq.com
 * @日期: 2020年6月22日下午5:28:49
 * @修改说明:<br> 
 * <pre>
 * 	 <li>作者: LiYuHui</li> 
 * 	 <li>日期: 2020年6月22日下午5:28:49</li> 
 *	 <li>内容: </li>
 * </pre>
 */
public interface BankTransferMoneyService {
	/**
	 * @方法名: transferMoney
	 * @方法说明: 转账的方法
	 * @作者: LiYuHui
	 * @邮箱:1327711913@qq.com
	 * @日期: 2020年6月22日下午5:30:13
	 * @param money
	 * @param user_idA
	 * @param user_idB
	 * @return: void
	 */
	public void transferMoney(double money,int user_idA,int user_idB);
}
/**@文件名: BankTransferMoneyServiceImpl.java
 * @类功能说明: 银行转账service层接口的实现类
 * @作者: LiYuHui
 * @Email: 1327711913@qq.com
 * @日期: 2020年6月22日下午5:30:46
 * @修改说明:<br> 
 * <pre>
 * 	 <li>作者: LiYuHui</li> 
 * 	 <li>日期: 2020年6月22日下午5:30:46</li> 
 *	 <li>内容: </li>
 * </pre>
 */
/*@Transactional*/
public class BankTransferMoneyServiceImpl implements BankTransferMoneyService {

	//注入Dao
	private BankTransferMoneyDao bankTransferMoneyDao;
	
	public void setBankTransferMoneyDao(BankTransferMoneyDao bankTransferMoneyDao) {
		this.bankTransferMoneyDao = bankTransferMoneyDao;
	}

	/**
	 * 转账
	 */
	@Override
	public void transferMoney(double money, int user_idA, int user_idB) {
		//转出
		bankTransferMoneyDao.outMoney(money, user_idA);
		//转入
		bankTransferMoneyDao.inMoney(money, user_idB);
	}
}

第四步 配置applicationContext.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
       	http://www.springframework.org/schema/context/spring-context.xsd
       	http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd
        http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
        ">
     
     <!-- 创建数据源dataSource(dbcp连接池) -->
     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
     	<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
    	<property name="url" value="jdbc:mysql://localhost:3306/db_bank?useUnicode=true&characterEncoding=utf-8"/>
       	<property name="username" value="root"/>
        <property name="password" value="123456"/>
     </bean>
     
     <!-- 配置事务管理 -->
     <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
     	<!-- 注入数据源 -->
     	<property name="dataSource" ref="dataSource"></property>
     </bean>
     
     <!-- 注入事务管理器(注解版) -->
     <!-- <tx:annotation-driven transaction-manager="transactionManager"/> -->
     
     <!-- 配置事务通知(XML版) -->
     <tx:advice id="txAdvice" transaction-manager="transactionManager">
     	<tx:attributes>
     		<!-- 指定所有的方法 -->
     		<tx:method name="*"/>
     	</tx:attributes>
     </tx:advice>
     
     <!-- 配置事务切面 -->
     <aop:config>
     	<aop:pointcut expression="execution(* com.lyh.service.*.*(..))" id="businessPoint"/>
     	<aop:advisor advice-ref="txAdvice" pointcut-ref="businessPoint"/>
     </aop:config>
     
	 <!-- 创建带参数的JDBC模板 -->
	 <bean id="namedParameterJdbcTemplate" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
	 	<constructor-arg ref="dataSource"></constructor-arg>
   	 </bean>
   	 
   	 <!-- 创建Dao层 -->
   	 <bean id="bankTransferMoneyDao" class="com.lyh.dao.impl.BankTransferMoneyDaoImpl">
   	 	<!-- 注入带参数的JDBC模板 -->
   	 	<property name="namedParameterJdbcTemplate" ref="namedParameterJdbcTemplate"></property>
   	 </bean>
   	 
   	 <!-- 创建Service层 -->
   	 <bean id="bankTransferMoneyService" class="com.lyh.service.impl.BankTransferMoneyServiceImpl">
   	 	<!-- 注入Dao层 -->
   	 	<property name="bankTransferMoneyDao" ref="bankTransferMoneyDao"></property>
   	 </bean>

</beans>

第五步 编写JUnit测试类进行测试

/**@文件名: TransferMoneyTest.java
 * @类功能说明: 转账测试类
 * @作者: LiYuHui
 * @Email: 1327711913@qq.com
 * @日期: 2020年6月22日下午5:54:54
 * @修改说明:<br> 
 * <pre>
 * 	 <li>作者: LiYuHui</li> 
 * 	 <li>日期: 2020年6月22日下午5:54:54</li> 
 *	 <li>内容: </li>
 * </pre>
 */
class TransferMoneyTest {

	private ApplicationContext ac = null;
	private BankTransferMoneyService bankTransferMoneyService = null;
	
	@BeforeEach
	void setUp() throws Exception {
		ac = new ClassPathXmlApplicationContext("applicationContext.xml");
		bankTransferMoneyService = (BankTransferMoneyService)ac.getBean("bankTransferMoneyService");
	}

	/**
	 * @方法名: transferMoney
	 * @方法说明: 转账测试
	 * @作者: LiYuHui
	 * @邮箱:1327711913@qq.com
	 * @日期: 2020年6月22日下午5:56:35
	 * @return: void
	 */
	@Test
	public void transferMoney() {
		bankTransferMoneyService.transferMoney(50, 1, 2);
	}
}

需要导的包:

  • dbcp:
  • commons-dbcp-1.4.jar
  • commons-pool.jar
  • jdbc:
  • mysql-connector-java-5.0.8-bin.jar
  • springAOP:
  • aopalliance.jar
  • aspectjweaver-1.6.6.jar
  • spring-aspects-4.0.6.RELEASE.jar
  • Spring的Jdbc模板:
  • spring-jdbc-4.0.6.RELEASE.jar
  • spring-tx-4.0.6.RELEASE.jar
  • spring核心jar包:
  • commons-logging.jar
  • spring-aop-4.0.6.RELEASE.jar
  • spring-beans-4.0.6.RELEASE.jar
  • spring-context-4.0.6.RELEASE.jar
  • spring-core-4.0.6.RELEASE.jar
  • spring-expression-4.0.6.RELEASE.jar