web-dev-qa-db-fra.com

L'initialisation de printemps Maven n'a pas pu instancier l'instance signalée par SLF4J LoggerFactory

Je suis le tutoriel https://spring.io/guides/gs/actuator-service/

Et quand j'essaie de lancer l'application, je reçois:

Échec de l'instanciation de l'exception signalée dans SLF4J LoggerFactory: Java.lang.NoClassDefFoundError: ch/qos/logback/core/joran/spi/JoranException à org.slf4j.LoggerFactory.bind (LoggerFactory.Java:150) à l'adresse org.slf4j.LoggerFactory.performInitialization (LoggerFactory.Java:124) at org.slf4j.LoggerFactory.getILoggerFactory (LoggerFactory.Java:412) à org.slf4j.LoggerFactory.getLogger (LoggerFactory.Java:357) à org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance (SLF4JLogFactory.Java:155) à org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance (SLF4JLogFactory.Java:132) à org.Apache.commons.logging.LogFactory.getLog (LogFactory.Java:273) à org.springframework.boot.SpringApplication. (SpringApplication.Java:189) à hello.HelloWorldConfiguration.main (HelloWorldConfiguration.Java:11) Causée par: Java.lang.ClassNotFoundException: ch.qos.logback.core.joran.spi.JoranException à Java.net.URLClassLoader.findClass (URLClassLoader.Java:381) à Java.lang.ClassLoader.loadClass (ClassLoader.Java:424) à l'adresse Sun.misc.Launcher $ AppClassLoader.loadClass (Launcher.Java:331) à Java.lang.ClassLoader.loadClass (ClassLoader.Java:357) ... 9 autres Exception dans le fil "principal" Java.lang.NoClassDefFoundError: ch/qos/logback/core/joran/spi/JoranException à org.slf4j.LoggerFactory.bind (LoggerFactory.Java:150) à l'adresse org.slf4j.LoggerFactory.performInitialization (LoggerFactory.Java:124) at org.slf4j.LoggerFactory.getILoggerFactory (LoggerFactory.Java:412) à org.slf4j.LoggerFactory.getLogger (LoggerFactory.Java:357) à org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance (SLF4JLogFactory.Java:155) à org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance (SLF4JLogFactory.Java:132) à org.Apache.commons.logging.LogFactory.getLog (LogFactory.Java:273) à org.springframework.boot.SpringApplication. (SpringApplication.Java:189) à hello.HelloWorldConfiguration.main (HelloWorldConfiguration.Java:11) Causée par: Java.lang.ClassNotFoundException: ch.qos.logback.core.joran.spi.JoranException à Java.net.URLClassLoader.findClass (URLClassLoader.Java:381) à Java.lang.ClassLoader.loadClass (ClassLoader.Java:424) à l'adresse Sun.misc.Launcher $ AppClassLoader.loadClass (Launcher.Java:331) à Java.lang.ClassLoader.loadClass (ClassLoader.Java:357) ... 9 plus

Mon fichier pom ressemble à ceci:

<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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.4.1.RELEASE</version>
  </parent>

  <groupId>sample.api</groupId>
  <artifactId>api.test</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <name>api.testMaven Webapp</name>
  <url>http://maven.Apache.org</url>

  <dependencies>
    <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
     </dependency>
     <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-actuator</artifactId>
     </dependency>
     <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
     </dependency>
  </dependencies>

  <properties>
      <Java.version>1.8</Java.version>
  </properties>

  <build>
    <finalName>api.test</finalName>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
  </build>

</project>

Et je ne sais pas comment résoudre ce problème. J'ai essayé de nettoyer et de reconstruire, voire de réimporter. J'ai regardé des questions similaires comme ceci , Mais rien ne semble fonctionner.

La seule façon dont j'ai pu exécuter le programme a été de changer le pom parent en version 1.3.1.RELEASE. Mais je ne veux pas utiliser cette version ni utiliser 1.4.1.RELEASE.

Toute aide serait grandement appréciée.Voici la dépendance mvn: tree.

[INFO] --- maven-dependency-plugin:2.10:tree (default-cli) @ api.test --- [INFO] sample.api:api.test:jar:0.0.1-SNAPSHOT [INFO] +- org.springframework.boot:spring-boot-starter-web:jar:1.4.1.RELEASE:com pile [INFO] | +- org.springframework.boot:spring-boot-starter:jar:1.4.1.RELEASE:comp ile [INFO] | | +- org.springframework.boot:spring-boot:jar:1.4.1.RELEASE:compile [INFO] | | +- org.springframework.boot:spring-boot-autoconfigure:jar:1.4.1.REL EASE:compile [INFO] | | +- org.springframework.boot:spring-boot-starter-logging:jar:1.4.1.R ELEASE:compile [INFO] | | | +- ch.qos.logback:logback-classic:jar:1.1.7:compile [INFO] | | | +- org.slf4j:jcl-over-slf4j:jar:1.7.21:compile [INFO] | | | +- org.slf4j:jul-to-slf4j:jar:1.7.21:compile [INFO] | | | \- org.slf4j:log4j-over-slf4j:jar:1.7.21:compile [INFO] | | \- org.yaml:snakeyaml:jar:1.17:runtime [INFO] | +- org.springframework.boot:spring-boot-starter-Tomcat:jar:1.4.1.RELEA SE:compile [INFO] | | +- org.Apache.Tomcat.embed:Tomcat-embed-core:jar:8.5.5:compile [INFO] | | +- org.Apache.Tomcat.embed:Tomcat-embed-el:jar:8.5.5:compile [INFO] | | \- org.Apache.Tomcat.embed:Tomcat-embed-websocket:jar:8.5.5:compile [INFO] | +- org.hibernate:hibernate-validator:jar:5.2.4.Final:compile [INFO] | | +- javax.validation:validation-api:jar:1.1.0.Final:compile [INFO] | | +- org.jboss.logging:jboss-logging:jar:3.3.0.Final:compile [INFO] | | \- com.fasterxml:classmate:jar:1.3.1:compile [INFO] | +- com.fasterxml.jackson.core:jackson-databind:jar:2.8.3:compile [INFO] | | +- com.fasterxml.jackson.core:jackson-annotations:jar:2.8.3:compile [INFO] | | \- com.fasterxml.jackson.core:jackson-core:jar:2.8.3:compile [INFO] | +- org.springframework:spring-web:jar:4.3.3.RELEASE:compile [INFO] | | +- org.springframework:spring-aop:jar:4.3.3.RELEASE:compile [INFO] | | +- org.springframework:spring-beans:jar:4.3.3.RELEASE:compile [INFO] | | \- org.springframework:spring-context:jar:4.3.3.RELEASE:compile [INFO] | \- org.springframework:spring-webmvc:jar:4.3.3.RELEASE:compile [INFO] | \- org.springframework:spring-expression:jar:4.3.3.RELEASE:compile [INFO] +- org.springframework.boot:spring-boot-starter-actuator:jar:1.4.1.RELEAS E:compile [INFO] | \- org.springframework.boot:spring-boot-actuator:jar:1.4.1.RELEASE:com pile [INFO] \- org.springframework.boot:spring-boot-starter-test:jar:1.4.1.RELEASE:te st [INFO] +- org.springframework.boot:spring-boot-test:jar:1.4.1.RELEASE:test [INFO] +- org.springframework.boot:spring-boot-test-autoconfigure:jar:1.4.1.R ELEASE:test [INFO] +- com.jayway.jsonpath:json-path:jar:2.2.0:test [INFO] | +- net.minidev:json-smart:jar:2.2.1:test [INFO] | | \- net.minidev:accessors-smart:jar:1.1:test [INFO] | | \- org.ow2.asm:asm:jar:5.0.3:test [INFO] | \- org.slf4j:slf4j-api:jar:1.7.21:compile [INFO] +- junit:junit:jar:4.12:test [INFO] +- org.assertj:assertj-core:jar:2.5.0:test [INFO] +- org.mockito:mockito-core:jar:1.10.19:test [INFO] | \- org.objenesis:objenesis:jar:2.1:test [INFO] +- org.hamcrest:hamcrest-core:jar:1.3:test [INFO] +- org.hamcrest:hamcrest-library:jar:1.3:test [INFO] +- org.skyscreamer:jsonassert:jar:1.3.0:test [INFO] | \- org.json:json:jar:20140107:test [INFO] +- org.springframework:spring-core:jar:4.3.3.RELEASE:compile [INFO] \- org.springframework:spring-test:jar:4.3.3.RELEASE:test [INFO] ------------------------------------------------------------------------

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-api</artifactId>
  <version>1.7.5</version>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>jcl-over-slf4j</artifactId>
  <version>1.7.5</version>
  <scope>runtime</scope>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-log4j12</artifactId>
  <version>1.7.5</version>
  <scope>runtime</scope>
</dependency>

SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/C:/Users/Josh/.m2/repository/ch/qos/logback/logback-classic/1.1.7/logback-classic-1.1.7.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: Found binding in [jar:file:/C:/Users/Josh/.m2/repository/org/slf4j/slf4j-log4j12/1.7.21/slf4j-log4j12-1.7.21.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation. Failed to instantiate SLF4J LoggerFactory Reported exception: Java.lang.NoClassDefFoundError: ch/qos/logback/core/joran/spi/JoranException at org.slf4j.LoggerFactory.bind(LoggerFactory.Java:150) at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.Java:124) at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.Java:412) at org.slf4j.LoggerFactory.getLogger(LoggerFactory.Java:357) at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:155) at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:132) at org.Apache.commons.logging.LogFactory.getLog(LogFactory.Java:273) at org.springframework.boot.SpringApplication.(SpringApplication.Java:189) at hello.HelloWorldConfiguration.main(HelloWorldConfiguration.Java:11) Caused by: Java.lang.ClassNotFoundException: ch.qos.logback.core.joran.spi.JoranException at Java.net.URLClassLoader.findClass(URLClassLoader.Java:381) at Java.lang.ClassLoader.loadClass(ClassLoader.Java:424) at Sun.misc.Launcher$AppClassLoader.loadClass(Launcher.Java:331) at Java.lang.ClassLoader.loadClass(ClassLoader.Java:357) ... 9 more Exception in thread "main" Java.lang.NoClassDefFoundError: ch/qos/logback/core/joran/spi/JoranException at org.slf4j.LoggerFactory.bind(LoggerFactory.Java:150) at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.Java:124) at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.Java:412) at org.slf4j.LoggerFactory.getLogger(LoggerFactory.Java:357) at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:155) at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:132) at org.Apache.commons.logging.LogFactory.getLog(LogFactory.Java:273) at org.springframework.boot.SpringApplication.(SpringApplication.Java:189) at hello.HelloWorldConfiguration.main(HelloWorldConfiguration.Java:11) Caused by: Java.lang.ClassNotFoundException: ch.qos.logback.core.joran.spi.JoranException at Java.net.URLClassLoader.findClass(URLClassLoader.Java:381) at Java.lang.ClassLoader.loadClass(ClassLoader.Java:424) at Sun.misc.Launcher$AppClassLoader.loadClass(Launcher.Java:331) at Java.lang.ClassLoader.loadClass(ClassLoader.Java:357) ... 9 more

5
user2719805

Les actions ci-dessous ont fonctionné pour moi

  1. Exécutez mvn dependency:purge-local-repository pour supprimer toutes les dépendances et forcer un nouveau téléchargement. 
  2. Ensuite, faites un mvn clean verify
29
Adi

J'ajoute cette dépendance et le problème résolu.

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-core</artifactId>
    <version>${logback.version}</version>
</dependency>

vous utilisez simplement la version de logback-classic si this error est survenu.

7
amir110

Vous devez trouver log4j et ajouter votre chemin de classe.

1
Jay

Le problème n'existe pas avec la version 1.3.5. J'ai changé ma version en 

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.3.5.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>

Ça marche !!

0
InvincibleCoder

Voir ce message: (vous gérez la duplication de dépendance, pour transitive de dépendance, causant une duplication de dépendance avec différentes versions)

Le chemin de classe contient plusieurs liaisons SLF4J. SLF4J: Reliure trouvée dans

faire un test si vous utilisez IDE Eclipse

touche de raccourci: Shift+Ctrl+T

de cette façon, vous voyez quel fichier contient cette classe:

SLF4J: Found binding in [jar:file:
/C:/Users/Josh/.m2/repository/ch/qos/logback/logback-classic/1.1.7/logback-classic-1.1.7.jar!
/org/slf4j/impl/StaticLoggerBinder.class]
[jar:file:/C:/Users/Josh/.m2/repository/org/slf4j/slf4j-log4j12/1.7.21/slf4j-log4j12-1.7.21.jar!
/org/slf4j/impl/StaticLoggerBinder.class]

répéter la classe dans

slf4j-log4j12-1.7.21.jar
logback-classic-1.1.7.jar

trouvez votre même dépendance et exclusion de ce dont vous n'avez pas besoin dans votre projet

de cette façon:

<dependency>
<groupId>org.seleniumhq.Selenium</groupId>
<artifactId>Selenium-Java</artifactId>
<version>3.0.0-beta2</version>
<scope>test</scope>
<exclusions>
    <exclusion>
        <artifactId>xml-apis</artifactId>
        <groupId>xml-apis</groupId>
    </exclusion>
</exclusions>

qu'un exemple, changez pour votre contexte

0
Marcelo Ferreira

Nous pouvons ignorer la dépendance à la journalisation et cela fonctionnera pour nous.

`<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>`
0
Brameshwar Gupta

Cela peut être un problème de version, Je change ma version de springboot de 2.0.0.RELEASE à 1.5.4.RELEASE, L’exception a disparu.

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.4.RELEASE</version>
</parent>
0
bourne