2017-06-05 169 views
1

Spring的启动杰克逊错误我有一个非常奇怪的问题,使用Maven的Spring-boot 1.5.2构建war包,它与Jackson依赖关系有错误,仅在Ubuntu 16.04上,因为我使用的是另一个Centos 7,并且没有将应用程序打开为war或jar文件的问题。与Maven的war文件,但没有jar文件与com.fasterxml.jackson.core.JsonFactory.requiresPropertyOrdering()Z

与Maven构建到JAR或战争结束后,我可以运行内置包

javar -jar target/project.war (or project.jar) 

和嵌入式Tomcat将启动。也可以将war包部署到Centos 7的webapps目录中的外部Tomcat。对于Ubuntu 16.04,我只能运行Tomcat嵌入的.jar文件,而不能使用Tomcat Embedded/External运行war文件。

Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.boot.web.filter.OrderedHttpPutFormContentFilter]: Factory method 'httpPutFormContentFilter' threw exception; nested exception is java.lang.NoSuchMethodError: com.fasterxml.jackson.core.JsonFactory.requiresPropertyOrdering()Z 
    at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:189) 
    at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:588) 
    ... 26 more 
Caused by: java.lang.NoSuchMethodError: com.fasterxml.jackson.core.JsonFactory.requiresPropertyOrdering()Z 
    at com.fasterxml.jackson.databind.ObjectMapper.<init>(ObjectMapper.java:564) 
    at com.fasterxml.jackson.databind.ObjectMapper.<init>(ObjectMapper.java:474) 
    at org.springframework.http.converter.json.Jackson2ObjectMapperBuilder.build(Jackson2ObjectMapperBuilder.java:588) 
    at org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.<init>(MappingJackson2HttpMessageConverter.java:57) 
    at org.springframework.http.converter.support.AllEncompassingFormHttpMessageConverter.<init>(AllEncompassingFormHttpMessageConverter.java:61) 
    at org.springframework.web.filter.HttpPutFormContentFilter.<init>(HttpPutFormContentFilter.java:63) 
    at org.springframework.boot.web.filter.OrderedHttpPutFormContentFilter.<init>(OrderedHttpPutFormContentFilter.java:29) 
    at org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration.httpPutFormContentFilter(WebMvcAutoConfiguration.java:142) 

这里是POM文件https://pastebin.com/13MwTm89我只能从杰克逊再添依赖于XML反序列化到对象。

<dependency> 
    <groupId>com.fasterxml.jackson.dataformat</groupId> 
    <artifactId>jackson-dataformat-xml</artifactId> 
    <version>2.8.7</version> 
</dependency> 

这里是杰克逊

mvn dependency:tree | grep 'jackson' 
[INFO] +- com.fasterxml.jackson.dataformat:jackson-dataformat-xml:jar:2.8.7:compile 
[INFO] | +- com.fasterxml.jackson.core:jackson-core:jar:2.8.7:compile 
[INFO] | +- com.fasterxml.jackson.core:jackson-annotations:jar:2.8.0:compile 
[INFO] | +- com.fasterxml.jackson.core:jackson-databind:jar:2.8.7:compile 
[INFO] | +- com.fasterxml.jackson.module:jackson-module-jaxb-annotations:jar:2.8.7:compile 
+0

为什么使用'jackson-annotations:jar:2.8.0',其余的都是2.8.7? – StanislavL

+0

这不是从我这里,它是从Spring引导依赖父。 –

+0

尝试降级您的版本。或者排除弹簧的依赖关系,并添加正确版本 – StanislavL

回答

0

我终于发现了问题试图注释掉每个单独的依赖pom.xml中后全部依赖关系,这是由于fasterxml从非常古老的版本一个为jar文件生成的内部项目,我包含在主项目的pom.xml中。

内部项目包含一些依赖关系,我认为其中一个包含这个老杰克逊核心库,我认为它是grpc或protobuf。

<dependencies> 
     <dependency> 
      <groupId>io.grpc</groupId> 
      <artifactId>grpc-all</artifactId> 
      <version>0.12.0</version> 
     </dependency> 
     <dependency> 
      <groupId>com.google.protobuf</groupId> 
      <artifactId>protobuf-java</artifactId> 
      <version>3.0.0-beta-1</version> 
     </dependency> 

     <dependency> 
      <groupId>junit</groupId> 
      <artifactId>junit</artifactId> 
      <version>4.12</version> 
     </dependency> 
    </dependencies> 

不知怎的,在Ubuntu 16.04,Maven的3.3.9喜欢这个杰克逊核心,而不是最新版本,从春天启动,或直接在pom.xml中指定。

在CentOS 7中使用Maven 3.5.0时不会发生这种情况,因为它使用最新的依赖关系时,Jackson运行时没有问题。

相关问题