Репозитории данных Spring не работают после включения Spring AOP [JAVA 11] - PullRequest
0 голосов
/ 10 ноября 2018

Привет, у меня есть приложение, использующее Spring 5, Spring Data и Spring AOP и Java 11 (я также использую модульную систему JAVA 9). Моя версия Spring-context / Spring-аспекты - 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 голосов
/ 10 ноября 2018

Попробуйте добавить AOP lib в ваши зависимости

<!-- https://mvnrepository.com/artifact/org.springframework/spring-aop -->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-aop</artifactId>
    <version>5.1.2.RELEASE</version>
</dependency>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...