启用S​​pring AOP后,Spring数据存储库不起作用[JAVA 11]

时间:2018-11-10 09:18:36

标签: spring spring-data-jpa spring-aop java-11

嗨,我有一个使用Spring 5,Spring Data,Spring AOP和Java 11的应用程序(我也使用JAVA 9模块系统)。 我的spring-context / spring-aspects版本是5.1.2。 Spring Data版本是2.1.2.RELEASE 这两个版本都是最新的。 我以以下方式创建存储库:

@Repository
public interface AirportRepository extends JpaRepository<Airport, Long> {
}

我已使用

启用了Spring数据存储库
@Configuration
@EnableTransactionManagement
@PropertySource("classpath:persistence-jndi.properties")
@PropertySource("classpath:hibernate.properties")
@EnableJpaRepositories(basePackages = "com.xx.yy.persistence")
public class PersistenceJNDIConfig {
  //Datasource configs
}

在使用以下配置引入Spring AOP之前,它一直运行良好。

@ComponentScan(basePackages = "com.xx.yy")
@EnableAspectJAutoProxy(exposeProxy = true)
public class AdminServicesConfiguration {
}

@Aspect
@Component
public class DasErrorHandler {

    @Around("@target(com.xx.yy.commons.aop.ErrorManagedDAS)")
    public Object handle(ProceedingJoinPoint proceedingJoinPoint){
        //Some code
    }
}

但是现在在服务器启动时,出现以下错误:

Caused by: java.lang.IllegalStateException: Cannot convert value of type 'com.sun.proxy.$Proxy82 implementing org.springframework.data.util.Streamable,org.springframework.aop.SpringProxy,org.springframework.aop.framework.Advised,org.springframework.core.DecoratingProxy' to required type 'org.springframework.data.repository.core.support.RepositoryComposition$RepositoryFragments' for property 'repositoryFragments': no matching editors or conversion strategy found
    at org.springframework.beans.TypeConverterDelegate.convertIfNecessary(TypeConverterDelegate.java:299)
    at org.springframework.beans.AbstractNestablePropertyAccessor.convertIfNecessary(AbstractNestablePropertyAccessor.java:585)
    ... 103 more

似乎由Spring生成的代理类型不匹配,这导致了上述错误,我尝试通过以下方式强制Spring使用CGLIB代理:

@EnableAspectJAutoProxy(exposeProxy = true, proxyTargetClass = true )

然后,即使我的类路径上有SpringProxy类,错误也会变为以下错误。请帮助:

Caused by: org.springframework.aop.framework.AopConfigException: Could not generate CGLIB subclass of class org.apache.tomcat.dbcp.dbcp2.BasicDataSource: Common causes of this problem include using a final class or a non-visible class; nested exception is org.springframework.cglib.core.CodeGenerationException: java.lang.NoClassDefFoundError-->org/springframework/aop/SpringProxy
    at org.springframework.aop.framework.CglibAopProxy.getProxy(CglibAopProxy.java:208)
    at org.springframework.aop.framework.ProxyFactory.getProxy(ProxyFactory.java:110)
    at org.springframework.aop.framework.autoproxy.AbstractAutoProxyCreator.createProxy(AbstractAutoProxyCreator.java:473)
    at org.springframework.aop.framework.autoproxy.AbstractAutoProxyCreator.wrapIfNecessary(AbstractAutoProxyCreator.java:352)
    at org.springframework.aop.framework.autoproxy.AbstractAutoProxyCreator.postProcessAfterInitialization(AbstractAutoProxyCreator.java:301)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsAfterInitialization(AbstractAutowireCapableBeanFactory.java:434)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1749)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:576)
    ... 88 more
Caused by: org.springframework.cglib.core.CodeGenerationException: java.lang.NoClassDefFoundError-->org/springframework/aop/SpringProxy
    at org.springframework.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:503)
    at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:359)
    at org.springframework.cglib.proxy.Enhancer.generate(Enhancer.java:582)
    at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:106)
    at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:104)
    at org.springframework.cglib.core.internal.LoadingCache$2.call(LoadingCache.java:54)
    at java.base/java.util.concurrent.FutureTask.run$$$capture(FutureTask.java:264)
    at java.base/java.util.concurrent.FutureTask.run(FutureTask.java)
    at org.springframework.cglib.core.internal.LoadingCache.createEntry(LoadingCache.java:61)
    at org.springframework.cglib.core.internal.LoadingCache.get(LoadingCache.java:34)
    at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData.get(AbstractClassGenerator.java:130)
    at org.springframework.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:315)
    at org.springframework.cglib.proxy.Enhancer.createHelper(Enhancer.java:569)
    at org.springframework.cglib.proxy.Enhancer.createClass(Enhancer.java:416)
    at org.springframework.aop.framework.ObjenesisCglibAopProxy.createProxyClassAndInstance(ObjenesisCglibAopProxy.java:58)
    at org.springframework.aop.framework.CglibAopProxy.getProxy(CglibAopProxy.java:205)
    ... 95 more
Caused by: java.lang.NoClassDefFoundError: org/springframework/aop/SpringProxy
    at java.base/java.lang.ClassLoader.defineClass1(Native Method)
    at java.base/java.lang.System$2.defineClass(System.java:2123)
    at java.base/java.lang.invoke.MethodHandles$Lookup.defineClass(MethodHandles.java:962)
    at java.base/jdk.internal.reflect.GeneratedMethodAccessor42.invoke(Unknown Source)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:566)
    at org.springframework.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:498)
    ... 110 more
Caused by: java.lang.ClassNotFoundException: org.springframework.aop.SpringProxy
    at java.base/java.net.URLClassLoader.findClass(URLClassLoader.java:471)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:588)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
    ... 117 more

编辑:模块的module-info.java如下

module com.xx.yy.admin.services {
    //External
    requires spring.webmvc;
    requires spring.web;
    requires spring.context;
    requires javax.servlet.api;
    requires org.apache.commons.collections4;
    requires org.apache.logging.log4j;
    requires org.apache.logging.log4j.core;
    requires spring.aop;
    requires org.aspectj.weaver;
    requires spring.aspects;

    //Internal
    requires com.xx.yy.utils;
    requires com.xx.yy.persistence;
}

module com.xx.yy.persistence {
    requires spring.context;
    requires spring.beans;
    requires spring.core;
    requires spring.data.commons;
    requires spring.data.jpa;
    requires spring.tx;
    requires spring.jdbc;
    requires spring.orm;
    requires spring.aop;
    requires java.sql;
    requires java.persistence;
    requires java.naming;
    requires java.xml;
}

module com.xx.yy.utils {
    requires com.fasterxml.jackson.core;
    requires com.fasterxml.jackson.databind;
    requires com.fasterxml.jackson.datatype.jsr310;
    requires orika.core;
    requires spring.context;
    requires org.aspectj.weaver;
    requires spring.aspects;
}

1 个答案:

答案 0 :(得分:0)

尝试将AOP库添加到依赖项

x <- c(1,1,2,3,5)
n <- length(x)
res <- 5
unique(combn(c(x,rep(0,n-1)), n, function(x) x[x!=0][sum(x)==res], FALSE))[-1]
# [[1]]
# [1] 1 1 3
# 
# [[2]]
# [1] 2 3
# 
# [[3]]
# [1] 5
#