【问题标题】:Conflict of Jackson dependencies / Tomcat杰克逊依赖/ Tomcat的冲突
【发布时间】:2016-02-26 02:30:07
【问题描述】:

我的java类在tomcat上部署时抛出这个错误:

org.apache.jasper.JasperException: 
javax.servlet.ServletException: java.lang.NoSuchMethodError: com.fasterxml.jackson.core.JsonParser.getValueAsString()Ljava/lang/String;
org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:556)

在本地测试时,该类运行得非常好。我知道杰克逊版本可能有冲突,但我找不到。

这是我的 pom.xml 的摘录

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.skylads.skott.webapp</groupId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>war</packaging>
    <name>Skylads CRM App</name>
    <description>CRM App integrating various features</description>
    <build>
        <sourceDirectory>src</sourceDirectory>
        <resources>
            <resource>
                <directory>src</directory>
                <excludes>
                    <exclude>**/*.java</exclude>
                </excludes>
            </resource>
            <resource>
                <directory>resources</directory>
                <excludes>
                    <exclude>**/*.java</exclude>
                </excludes>
            </resource>
        </resources>
        <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <source>1.7</source>
                    <target>1.7</target>
                </configuration>
            </plugin>
            <plugin>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <warSourceDirectory>WebContent</warSourceDirectory>
                    <failOnMissingWebXml>false</failOnMissingWebXml>
                </configuration>
            </plugin>
        </plugins>
    </build>
    <artifactId>crm</artifactId>
    <dependencies>
        <dependency>
            <groupId>com.google.apis</groupId>
            <artifactId>google-api-services-oauth2</artifactId>
            <exclusions>
                <exclusion>
                    <artifactId>jackson-core</artifactId>
                    <groupId>com.fasterxml.jackson.core</groupId>
                </exclusion>
            </exclusions>
            <version>v2-rev98-1.20.0</version>
        </dependency>

        <dependency>
            <groupId>com.google.apis</groupId>
            <artifactId>google-api-services-plus</artifactId>
            <version>v1-rev323-1.21.0</version>
        </dependency>
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.5</version>
        </dependency>
        <dependency>
            <groupId>com.google.oauth-client</groupId>
            <artifactId>google-oauth-client-java6</artifactId>
            <version>1.21.0</version>
        </dependency>

        <dependency>
            <groupId>com.google.http-client</groupId>
            <artifactId>google-http-client-jackson</artifactId>
            <version>1.20.0</version>
        </dependency>
        <dependency>
            <groupId>com.google.oauth-client</groupId>
            <artifactId>google-oauth-client</artifactId>
            <version>1.21.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
            <version>4.5.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.tomcat</groupId>
            <artifactId>tomcat-jdbc</artifactId>
            <version>7.0.35</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.38</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
        <dependency>
            <groupId>org.scribe</groupId>
            <artifactId>scribe</artifactId>
            <version>1.1.2</version>
        </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.fasterxml.jackson.core</groupId>
                <artifactId>jackson-core</artifactId>
                <version>2.1.3</version>
            </dependency>
            <dependency>
                <groupId>com.fasterxml.jackson.core</groupId>
                <artifactId>jackson-databind</artifactId>
                <version>2.1.3</version>
            </dependency>
        </dependencies>
    </dependencyManagement>
</project>

应用程序在 Tomcat 7.0 上运行。 编辑:添加了完整的pom.xml 非常感谢任何帮助。

【问题讨论】:

标签: java maven jackson


【解决方案1】:

好的,伙计们,我已经摆脱了这个噩梦。我使用http://jhades.org/ 来识别重叠的 jar,进入 web-inf 并删除了冲突并造成问题的旧 jar。

Maven 很酷,但不能解决所有问题,我在这个问题上浪费了 3 个小时以上...

再次感谢您非常有帮助的贡献。

苏菲

【讨论】:

    【解决方案2】:

    正如您在 tomcat 上所说,您使用的 jackson-core 版本与您的构建版本不同。 用 mvn help:effective-pom 找出你在 maven 中使用的东西 比看看你在战争中打包了什么。 也有可能是tomcat使用了自己的jackson库导致了这个问题。

    【讨论】:

      【解决方案3】:

      您没有提供有关您的问题的详细信息,但我可以告诉您,2.1.0 版是第一个具有getValueAsString 方法的版本。您的 pom.xml 中的 version 也确实有它。旧版本没有它,这就是您的问题所在。所以根据我的经验,这显然是一个问题,你有两个 jackson-core jar 版本正在运行并且类加载器首先获取旧版本。您需要执行以下操作:

      $ find . -name "*jackson*"
      

      在您的 tomcat 7 目录中。找到旧版本并将其从您的集成中删除。阅读 tomcat 7 网页以了解有关您的 tomcat 版本的类加载器的更多信息。

      【讨论】:

        猜你喜欢
        • 2018-12-12
        • 2017-03-08
        • 2015-05-24
        • 1970-01-01
        • 2023-04-03
        • 2015-04-19
        • 2016-09-10
        • 2016-08-07
        • 1970-01-01
        相关资源
        最近更新 更多