【问题标题】:Java 9 - REST with Spring 5 & Jigsaw - Is it possible?Java 9 - REST with Spring 5 & Jigsaw - 有可能吗?
【发布时间】:2017-01-22 00:33:11
【问题描述】:

我一直在研究 JDK 9 的 Jigsaw 模块化系统。

从命令行编译时效果很好(至少quickstart 可以)。

但我正在尝试使用 Spring 和 Jigsaw 创建一个简单的 REST API。 Spring 5.0.0 M1据说有

自 2016 年 7 月起与 JDK 9 完全兼容

我还希望 REST API 可以与 Maven 一起使用。根据this Maven page, Maven 应该能够使用 Java 9(或者我读错了吗?)。

当我的 JAVA_HOME 指向我的 JDK 时,我似乎无法在我的 Spring Boot 应用程序上运行 mvn spring-boot:run - 它会引发很多异常,例如:

FoundError: javax/xml/bind/ValidationException
2016-09-14 10:43:42.704 ERROR 120408 --- [           main] o.s.boot.SpringApplication               : Application startup failed

运行mvn -version 给了我:

Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-11-10T17:41:47+01:00)
Maven home: C:\Program Files\apache-maven-3.3.9\bin\..
Java version: 9-ea, vendor: Oracle Corporation
Java home: C:\Program Files\Java\jdk-9
Default locale: en_US, platform encoding: Cp1252
OS name: "windows 10", version: "10.0", arch: "amd64", family: "dos"

目前是否可以使用 Jigsaw 使用 Spring 和 Java 9 创建此 REST API?或者我应该坚持使用 Java 8 直到 2017 年 3 月/7 月左右?

全栈转储:

2016-09-14 10:43:42.688  WARN 120408 --- [           main] ationConfigEmbeddedWebApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.context.ApplicationContextException:                          Unable to start embedded container; nested exception is org.springframework.bea                         ns.factory.BeanCreationException: Error creating bean with name 'tomcatEmbeddedS                         ervletContainerFactory' defined in class path resource [org/springframework/boot                         /autoconfigure/web/EmbeddedServletContainerAutoConfiguration$EmbeddedTomcat.clas                         s]: Initialization of bean failed; nested exception is org.springframework.beans                         .factory.UnsatisfiedDependencyException: Error creating bean with name 'org.spri                         ngframework.boot.autoconfigure.web.HttpEncodingAutoConfiguration': Unsatisfied d                         ependency expressed through constructor parameter 0: Error creating bean with na                         me 'spring.http.encoding-org.springframework.boot.autoconfigure.web.HttpEncoding                         Properties': Initialization of bean failed; nested exception is java.lang.NoClas                         sDefFoundError: javax/xml/bind/ValidationException; nested exception is org.spri                         ngframework.beans.factory.BeanCreationException: Error creating bean with name '                         spring.http.encoding-org.springframework.boot.autoconfigure.web.HttpEncodingProp                         erties': Initialization of bean failed; nested exception is java.lang.NoClassDef                         FoundError: javax/xml/bind/ValidationException
2016-09-14 10:43:42.704 ERROR 120408 --- [           main] o.s.boot.SpringApplication               : Application startup failed

org.springframework.context.ApplicationContextException: Unable to start embedded container; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'tomcatEmbeddedServletContainerFactory'                          defined in class path resource [org/springframework/boot/autoconfigure/web/Embed                         dedServletContainerAutoConfiguration$EmbeddedTomcat.class]: Initialization of be                         an failed; nested exception is org.springframework.beans.factory.UnsatisfiedDepe                         ndencyException: Error creating bean with name 'org.springframework.boot.autocon                         figure.web.HttpEncodingAutoConfiguration': Unsatisfied dependency expressed thro                         ugh constructor parameter 0: Error creating bean with name 'spring.http.encoding                         -org.springframework.boot.autoconfigure.web.HttpEncodingProperties': Initializat                         ion of bean failed; nested exception is java.lang.NoClassDefFoundError: javax/xm                         l/bind/ValidationException; nested exception is org.springframework.beans.factor                         y.BeanCreationException: Error creating bean with name 'spring.http.encoding-org                         .springframework.boot.autoconfigure.web.HttpEncodingProperties': Initialization                          of bean failed; nested exception is java.lang.NoClassDefFoundError: javax/xml/bi                         nd/ValidationException
        at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.onRefresh(EmbeddedWebApplicationContext.java:137) ~[spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:535) ~[spring-context-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) ~[spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:759) [spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:369) [spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:313) [spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:1185) [spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:1174) [spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at hello.Application.main(Application.java:10) [classes/:na]
        at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(java.base@9-ea/Native Method) ~[na:na]
        at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(java.base@9-ea/NativeMethodAccessorImpl.java:62) ~[na:na]
        at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(java.base@9-ea/DelegatingMethodAccessorImpl.java:43) ~[na:na]
        at java.lang.reflect.Method.invoke(java.base@9-ea/Method.java:535) ~[na:na]
        at org.springframework.boot.maven.AbstractRunMojo$LaunchRunner.run(AbstractRunMojo.java:483) [spring-boot-maven-plugin-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at java.lang.Thread.run(java.base@9-ea/Thread.java:843) [na:na]
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'tomcatEmbeddedServletContainerFactory' defined in class path resource [org/springframework/boot/autoconfigure/web/EmbeddedServletContainerAut                         oConfiguration$EmbeddedTomcat.class]: Initialization of bean failed; nested exce                         ption is org.springframework.beans.factory.UnsatisfiedDependencyException: Error                          creating bean with name 'org.springframework.boot.autoconfigure.web.HttpEncodin                         gAutoConfiguration': Unsatisfied dependency expressed through constructor parame                         ter 0: Error creating bean with name 'spring.http.encoding-org.springframework.b                         oot.autoconfigure.web.HttpEncodingProperties': Initialization of bean failed; ne                         sted exception is java.lang.NoClassDefFoundError: javax/xml/bind/ValidationExcep                         tion; nested exception is org.springframework.beans.factory.BeanCreationExceptio                         n: Error creating bean with name 'spring.http.encoding-org.springframework.boot.                         autoconfigure.web.HttpEncodingProperties': Initialization of bean failed; nested                          exception is java.lang.NoClassDefFoundError: javax/xml/bind/ValidationException
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:553) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:202) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.getEmbeddedServletContainerFactory(EmbeddedWebApplicationContext.java:199) ~[spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.createEmbeddedServletContainer(EmbeddedWebApplicationContext.java:162) ~[spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.onRefresh(EmbeddedWebApplicationContext.java:134) ~[spring-boot-1.4.0.RELEASE.jar:1.4.0.RELEASE]
        ... 14 common frames omitted
Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'org.springframework.boot.autoconfigure.web.HttpEncodingAutoConfiguration': Unsatisfied dependency expressed through constructor para                         meter 0: Error creating bean with name 'spring.http.encoding-org.springframework                         .boot.autoconfigure.web.HttpEncodingProperties': Initialization of bean failed;                          nested exception is java.lang.NoClassDefFoundError: javax/xml/bind/ValidationExc                         eption; nested exception is org.springframework.beans.factory.BeanCreationExcept                         ion: Error creating bean with name 'spring.http.encoding-org.springframework.boo                         t.autoconfigure.web.HttpEncodingProperties': Initialization of bean failed; nest                         ed exception is java.lang.NoClassDefFoundError: javax/xml/bind/ValidationExcepti                         on
        at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:749) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:189) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1143) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1046) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:510) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:372) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1123) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1018) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:510) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE]
        at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 

----切断

摘要错误:

[ERROR] Failed to execute goal org.springframework.boot:spring-boot-maven-plugin                         
:1.4.0.RELEASE:run (default-cli) on project gs-rest-service: An exception occurr                         
ed while running. null: InvocationTargetException: Unable to start embedded cont                         
ainer; nested exception is org.springframework.beans.factory.BeanCreationExcepti       
on: Error creating bean with name 'tomcatEmbeddedServletContainerFactory' define                         
d in class path resource [org/springframework/boot/autoconfigure/web/EmbeddedSer
vletContainerAutoConfiguration$EmbeddedTomcat.class]: Initialization of bean fai                    
led; nested exception is org.springframework.beans.factory.UnsatisfiedDependency              
Exception: Error creating bean with name 'org.springframework.boot.autoconfigure    
.web.HttpEncodingAutoConfiguration': Unsatisfied dependency expressed through co                         
nstructor parameter 0: Error creating bean with name 'spring.http.encoding-org.s           
pringframework.boot.autoconfigure.web.HttpEncodingProperties': Initialization of                          
bean failed; nested exception is java.lang.NoClassDefFoundError: javax/xml/bind                         
/ValidationException; nested exception is org.springframework.beans.factory.Bean                      
CreationException: Error creating bean with name 'spring.http.encoding-org.sprin            
gframework.boot.autoconfigure.web.HttpEncodingProperties': Initialization of bea                         
n failed; nested exception is java.lang.NoClassDefFoundError: javax/xml/bind/Val                         
idationException: javax.xml.bind.ValidationException -> [Help 1]

【问题讨论】:

  • 添加整个堆栈,我们实际上想看看你得到了什么异常。 “应用程序启动失败”对我们没有用。
  • 只剪掉最底层的异常。 How to read a stacktrace

标签: java spring rest maven java-9


【解决方案1】:
Initialization of bean failed; nested exception is java.lang.NoClassDefFoundError: javax/xml/bind/ValidationException: javax.xml.bind.ValidationException

您缺少一个依赖项,特别是 this one

【讨论】:

  • 这隐含地是由使用 Java 9 作为 JDK 引起的,因为这个 REST API 使用 Spring-boot 并且还没有与 JDK9/modules 兼容的 spring-boot 版本?或者有吗?
  • 你添加依赖了吗?发生了什么?
【解决方案2】:

由于您使用的是非默认模块,您需要在编译和运行 Java9 时手动添加:

javac --add-modules java.xml.bind ...
java  --add-modules java.xml.bind ...

如果还有其他缺少的 java ee 类尝试添加桶模块:

--add-module java.se.ee

【讨论】:

    【解决方案3】:

    罗夏的答案不正确,因为休眠验证异常位于不同的包、不同的类中。我没有足够的代表点数可以直接发表评论。

    zhy2002 的答案对于仅 Java-9 的情况是正确的,但不适用于 Java 8 或 10(因为此 java ee 模块已弃用,将在 10 中删除)。如果您希望它像我们一样与 Java 8 和 Java 9 一起使用,您可以添加此依赖项:

    分级:

    compile "javax.xml.bind:jaxb-api:2.3.0"
    

    马文:

    <!-- https://mvnrepository.com/artifact/javax.xml.bind/jaxb-api -->
    <dependency>
        <groupId>javax.xml.bind</groupId>
        <artifactId>jaxb-api</artifactId>
        <version>2.3.0</version>
    </dependency>
    

    请看这里:
    How to resolve java.lang.NoClassDefFoundError: javax/xml/bind/JAXBException in Java 9

    【讨论】:

      【解决方案4】:

      如果是 Spring Boot,你需要在 maven pom 中添加:

      <plugin>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-maven-plugin</artifactId>
          <configuration>
               <jvmArguments>--add-modules java.xml.bind</jvmArguments>
               <mainClass>org.springframework.samples.petclinic.PetClinicApplication</mainClass>
           </configuration>
      ...
      

      <dependency>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-starter-data-jpa</artifactId>
          <exclusions>
               <exclusion>
                   <artifactId>javassist</artifactId>
                   <groupId>org.javassist</groupId>
               </exclusion>
          </exclusions>
      </dependency>
      <dependency>
          <groupId>org.javassist</groupId>
          <artifactId>javassist</artifactId>
          <version>3.22.0-GA</version>
          <scope>runtime</scope>
      </dependency>
      

      https://blog.frankel.ch/migrating-to-java-9/2/

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2017-07-13
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2011-08-09
        • 2017-11-05
        • 2019-01-06
        相关资源
        最近更新 更多