回到事物的案例中
我们现在希望用代码比较精简的这个AccountServiceImpl这个类。而不是一堆事物的AccountServiceImpl_OLD这个类
新建BeanFactory类
AccountService需要通过spring注入的方式。所以这里提供了set方法
代理谁就写的类加载器。
复制这里的代码
复制过来,然后进行修改
这里有很多红色报错的地方。那就是tsManager这个对象。这就需要在上面定义。
把AccountServiceImpl_OLD中定义的tsManager和生成的set方法都复制过来
accountService需要是一个最终的对象。所以这里用final来修饰
这样这个代理对象就创建完了。同时也加上了事物
这样执行AccountServiceImpl这个被代理对象里面的任何方法时,都会经过代理对象。
被代理对象AccountServiceImpl内就不再需要tsManager。因为都由代理对象来控制了。
完成以上。事务控制和业务层的方法就进行了真正的分离
accountService中注入事务管理就不再需要了。
beanfacoty中注入Service
再注入事物管理器
配置代理的Service
之前的这里的accountService就是一个普通的Service对象,里面没有任何带事物支持的
这里我们不能再配置AccountServiceImpl这个类了。而是要用我们之前对象创建三种方式之一的实例工厂,也就是factory-bean
这样我们就出现了两个类型相同的。这两都实现了IAccountService接口,一个是动态代理实现的,一个本身就是实现类
那么我们测试的时候,用Autowired这种方式注入就不行了。因为这个再注入的时候二选一,选不出来
所以就需要用Qulifier。我们这里就用代理类的Service
在这里打印一句话
测试使用动态代码实现事务控制
出了一场,金额都没有变化
配置变的很繁琐。接下来就需要Spring中的AOP
阶段3 2.Spring_07.银行转账案例_10 使用动态代理实现事务控制
原文:https://www.cnblogs.com/wangjunwei/p/11354421.html