java.lang.NoSuchFieldError: org.apache.http.message.BasicLineFormatter.INSTANCE from Mashape Unirest in Java application

前端 未结 5 602
半阙折子戏
半阙折子戏 2020-11-29 22:45

I have a Maven Java project that uses Mashape Unirest for sending HTTP requests to other URLs. I am currently writing an integration test (using TestNG) tha

相关标签:
5条回答
  • 2020-11-29 22:56

    if you are using aws sdk this error occurs because of dependency mismatch. To avoid this error do the following: 1.Put the dependecies in the required order aws sdk and the end preferably 2.Add shade plugin to the project

    This solved my problem

    0 讨论(0)
  • 2020-11-29 23:05

    I faced the same exception using unirest:

    java.lang.NoSuchFieldError: INSTANCE
            at org.apache.http.impl.io.DefaultHttpRequestWriterFactory.<init>(DefaultHttpRequestWriterFactory.java:52)
    at com.mashape.unirest.http.options.Options.refresh(Options.java:55)
    at com.mashape.unirest.http.options.Options.<clinit>(Options.java:36)
    

    And found it was due to DefaultConnectionKeepAliveStrategy.INSTANCE; and the conflicting jar was apache-httpcomponents-httpclient.jar in my classpath. Adding this post to help anyone who faces similar exception

    0 讨论(0)
  • 2020-11-29 23:05

    I got this Exception: Caused by: java.lang.NoSuchFieldError: INSTANCE

    Solution:

    This happens if you have two different version classes in your classpath…. […], So I first find that class (one version of class), click that class, select build path, then I click remove from build path.

    0 讨论(0)
  • 2020-11-29 23:09

    The only plausible explanation to this problem is there is an older version of HttpCore on the classpath (unless you also want to consider a possibility of green men from Mars messing with your computer remotely from a flying saucer).

    You can add this snippet to your code to find out what jar the class gets picked up from. This might help find out why that jar is on your classpath in the first place.

    ClassLoader classLoader = MyClass.class.getClassLoader();
    URL resource = classLoader.getResource("org/apache/http/message/BasicLineFormatter.class");
    System.out.println(resource);
    

    This basically tells me that in my case the jar resides in the local maven repository and likely to have been added to the classpath by Maven

    jar:file:/home/oleg/.m2/repository/org/apache/httpcomponents/httpcore/4.3.1/httpcore-4.3.1.jar!/org/apache/http/message/BasicLineFormatter.class
    
    0 讨论(0)
  • 2020-11-29 23:12

    As already mentioned by previous comments, It's mainly because of the conflicting versions of httpcore jar, the static field INSTANCE is been added to BasicLineFormatter class in versions > 4.3.1, Though you might have added the latest version of the httpcore jar in your dependencies, but its highly possible that other (lower) version of jar is getting picked up.

    So, first to confirm that, wrong jar is getting picked up, Use the following line of code -

    ClassLoader classLoader = <Your Class>.class.getClassLoader();
    URL resource = classLoader.getResource("org/apache/http/message/BasicLineFormatter.class");
    System.out.println(resource);
    

    If this prints, the lower version of the jar, then it's confirmed that it's picking the lower version of the httpcore jar (May be from other dependencies of your project),

    Solution -

    Add following maven/gradle dependencies at the top of dependency list (Or above the other project dependency which caused the conflict) -

    <dependency>
         <groupId>com.mashape.unirest</groupId>
         <artifactId>unirest-java</artifactId>
         <version>1.4.5</version>
    </dependency>
    <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpcore</artifactId>
        <version>4.4.1</version>
    </dependency>
    <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpclient</artifactId>
        <version>4.4.1</version>
    </dependency>
    
    0 讨论(0)
提交回复
热议问题