2017-10-31 19 views
0

Java8からJava9 Springブートアプリケーションにアップグレードすると、次のエラーが発生します。 Java 9でサポートされていないspring-web-5.0.0.RELEASEとspring-webmvc-5.0.0.RELEASEの注釈はありますか?アプリケーションで受け取ったエラーから分かりません。Java 9、Spring Framework 5.0、Springブート2.0

2017-10-31 14:18:39.767 ERROR [org.springframework.boot.SpringApplication] [main] [] Application startup failed 
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'requestMappingHandlerMapping' defined in class path resource [org/springframework/boot/autoconfigure/web/servlet/WebMvcAutoConfiguration$EnableWebMvcConfiguration.class]: Invocation of init method failed; nested exception is java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1704) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:583) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:502) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:312) 
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:228) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:310) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:200) 
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:756) 
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:868) 
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:549) 
    at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:122) 
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:750) 
    at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:386) 
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:327) 
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1245) 
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1233) 
    at com.tsys.enterprise.issuing.account.application.Main.main(Main.java:30) 
Caused by: java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy 
    at java.base/sun.reflect.annotation.AnnotationParser.parseClassArray(AnnotationParser.java:724) 
    at java.base/sun.reflect.annotation.AnnotationParser.parseArray(AnnotationParser.java:531) 
    at java.base/sun.reflect.annotation.AnnotationParser.parseMemberValue(AnnotationParser.java:355) 
    at java.base/sun.reflect.annotation.AnnotationParser.parseAnnotation2(AnnotationParser.java:286) 
    at java.base/sun.reflect.annotation.AnnotationParser.parseAnnotations2(AnnotationParser.java:120) 
    at java.base/sun.reflect.annotation.AnnotationParser.parseAnnotations(AnnotationParser.java:72) 
    at java.base/java.lang.Class.createAnnotationData(Class.java:3730) 
    at java.base/java.lang.Class.annotationData(Class.java:3719) 
    at java.base/java.lang.Class.createAnnotationData(Class.java:3735) 
    at java.base/java.lang.Class.annotationData(Class.java:3719) 
    at java.base/java.lang.Class.getAnnotation(Class.java:3624) 
    at java.base/java.lang.reflect.AnnotatedElement.isAnnotationPresent(AnnotatedElement.java:262) 
    at java.base/java.lang.Class.isAnnotationPresent(Class.java:3634) 
    at org.springframework.core.annotation.AnnotatedElementUtils.hasAnnotation(AnnotatedElementUtils.java:610) 
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping.isHandler(RequestMappingHandlerMapping.java:177) 
    at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.initHandlerMethods(AbstractHandlerMethodMapping.java:217) 
    at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.afterPropertiesSet(AbstractHandlerMethodMapping.java:188) 
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping.afterPropertiesSet(RequestMappingHandlerMapping.java:129) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1763) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1700) 
+0

このアプリケーションはJava 8で動作していますか?Javaバージョンを変更しているときにのみ失敗しますか? –

+0

私はthymeleafでこれを扱うことに興奮しています。私は確実にj9とboot2に移行します – Antoniossss

+0

はい、そうです。それはJava8でうまく動作します。 – SSNM

答えて

0

あなたは、この他のチケットを見る場合はsun.reflect.annotation.TypeNotPresentExceptionProxy exception after adding EntityListeners

それはあなたがクラスパスにないクラスのアノテーションを持つことができTypeNotPresentExceptionProxyたyou're例外。

Java 9の最大/厄介な機能の1つは、モジュールシステムです。モジュールシステムでは、使用したい場合はパッケージ情報を指定する必要があります。

あなたのrequestMappingHandlerMappingクラスには、自分の理論を証明できるアノテーションが含まれていますか?

+0

Spring MVCクラスの「RequestMappingHandlerMapping」は単独でアノテーションです。 – SSNM