Spring Jersey Mybatis Aop transaction事务失效解决方案SpringManagedTransaction will not be managed by Spring

整个项目的框架是Spring + Jersey + Mybatis, 事务是用Aop做的,不是用注解的形式,一直报这样的错误:

DEBUG: org.mybatis.spring.transaction.SpringManagedTransaction - JDBC Connection [ConnectionHandle{url=jdbc:postgresql://localhost/mypro, user=mypro, debugHandle=null, lastResetAgoInSec=92, lastUsedAgoInSec=92, creationTimeAgoInSec=92}] will not be managed by Spring

在网上找了很多方案,发现都没解决我的事务问题:
http://www.codingpedia.org/ama/restful-web-services-example-in-java-with-jersey-spring-and-mybatis/

http://powertech.iteye.com/blog/2312452

https://www.cnblogs.com/dingchenghong/p/4858552.html

上面的资料都试过了,用注解的形式,单独跑过第一个项目是可以的,但是我现在是维护原来的项目,如果把以前的项目都改成注解的形式,工作量也是够大,所以还是要用Aop事务来处理,我的项目大致结构是:
service 接口
serviceImpl 接口实现类,实现接口,所有类上都加有@Servcie和@Path的注解
dao 接口
application.xml文件扫描所有的类
spring-mybatis.xml 数据源事务配置

    <aop:config>
        <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.xxxx.xx.service.*.*(..))" />

    aop:config>

刚开始配置文件是这样的,发现不管怎么试都不可以,还用

type="annotation" expression="org.springframework.stereotype.Service"/>

这个排除怀疑是service的重复扫描问题,还试了说是必须用@Component不能用@Service,来源:https://stackoverflow.com/questions/21104567/springjersey-transactional-annotation/24554236#24554236
但还是没有解决问题,还看来mybatis-spring的源码:

SpringManagedTransaction.java:

  private void openConnection() throws SQLException {
    this.connection = DataSourceUtils.getConnection(this.dataSource);
    this.autoCommit = this.connection.getAutoCommit();
    this.isConnectionTransactional = isConnectionTransactional(this.connection, this.dataSource);

    if (this.logger.isDebugEnabled()) {
      this.logger.debug(
          "JDBC Connection ["
              + this.connection
              + "] will"
              + (this.isConnectionTransactional ? " " : " not ")
              + "be managed by Spring");
    }
  }

DataSourceUtils.java:

    public static boolean isConnectionTransactional(Connection con, DataSource dataSource) {
        if (dataSource == null) {
            return false;
        }
        ConnectionHolder conHolder = (ConnectionHolder) TransactionSynchronizationManager.getResource(dataSource);
        return (conHolder != null && connectionEquals(conHolder, con));
    }

TransactionSynchronizationManager.java

    public static Object getResource(Object key) {
        Object actualKey = TransactionSynchronizationUtils.unwrapResourceIfNecessary(key);
        Object value = doGetResource(actualKey);
        if (value != null && logger.isTraceEnabled()) {
            logger.trace("Retrieved value [" + value + "] for key [" + actualKey + "] bound to thread [" +
                    Thread.currentThread().getName() + "]");
        }
        return value;
    }

发现通过Key,没有找到value
后来仔细看以前的配置文件,发现所有的事务都绑定在接口上了,我这里的事务要绑定在接口实现类上面,于是改成:


    


测试之后发现,还是不行,按照上面的思路,另外单独试验一个项目,就是把所有serviceImpl的实现接口的接口继承关系去掉,就是只有实现类serviceImpl,尽然发现奇迹成功了,于是想到之前有接触过proxy-target-class这个属性,当时记不太清,就是接口或者类的代理吧,于是查看资料,发现:
proxy-target-class属性值决定是基于接口的还是基于类的代理被创建。首先说明下proxy-target-class=”true”和proxy-target-class=”false”的区别,为true则是基于类的代理将起作用(需要cglib库),为false或者省略这个属性,则标准的JDK 基于接口的代理将起作用,proxy-target-class在spring事务、aop、缓存这几块都有设置,其作用都是一样的
茅塞顿开,于是把配置文件改成:

    <aop:config proxy-target-class="true">
        <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.xxxx.xx.service.impl.*.*(..))" />

    aop:config>

居然大功告成了,先总结到,会继续补齐解决方案!

事务信息如下:

2018-01-03 22:12:12,144 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,144 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,144 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,144 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @930981891 wrapping com.mysql.jdbc.JDBC4Connection@6d8a1a40]>
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @930981891 wrapping com.mysql.jdbc.JDBC4Connection@6d8a1a40]>
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1838470215 wrapping com.mysql.jdbc.JDBC4Connection@2cb7107b]>
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1092608611 wrapping com.mysql.jdbc.JDBC4Connection@615fb0b7]>
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1092608611 wrapping com.mysql.jdbc.JDBC4Connection@615fb0b7]>
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1974184653 wrapping com.mysql.jdbc.JDBC4Connection@5c2d12c4]>
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1974184653 wrapping com.mysql.jdbc.JDBC4Connection@5c2d12c4]>
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,145 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1838470215 wrapping com.mysql.jdbc.JDBC4Connection@2cb7107b]>
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,146 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - 
2018-01-03 22:12:12,209 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @930981891 wrapping com.mysql.jdbc.JDBC4Connection@6d8a1a40] after transaction>
2018-01-03 22:12:12,209 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @930981891 wrapping com.mysql.jdbc.JDBC4Connection@6d8a1a40] after transaction>
2018-01-03 22:12:12,219 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1974184653 wrapping com.mysql.jdbc.JDBC4Connection@5c2d12c4] after transaction>
2018-01-03 22:12:12,219 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1974184653 wrapping com.mysql.jdbc.JDBC4Connection@5c2d12c4] after transaction>
2018-01-03 22:12:12,223 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1092608611 wrapping com.mysql.jdbc.JDBC4Connection@615fb0b7] after transaction>
2018-01-03 22:12:12,223 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1092608611 wrapping com.mysql.jdbc.JDBC4Connection@615fb0b7] after transaction>
2018-01-03 22:12:12,225 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1838470215 wrapping com.mysql.jdbc.JDBC4Connection@2cb7107b] after transaction>
2018-01-03 22:12:12,225 DEBUG [org.springframework.jdbc.datasource.DataSourceTransactionManager] - @1838470215 wrapping com.mysql.jdbc.JDBC4Connection@2cb7107b] after transaction>

你可能感兴趣的:(jersey,事务,aop)