Gradle - Исключение в потоке "main" java.lang.NoClassDefFoundError: org / slf4j / LoggerFactory - PullRequest
0 голосов
/ 08 марта 2019

Файл Gradle:

buildscript {
    ext {
        springBootVersion = '1.5.6.RELEASE'
    }
    repositories {
        maven { url 'http://repo1.maven.org/maven2' }
        //maven { url 'https://mvnrepository.com/artifact/org.slf4j/slf4j-api' }
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
        //compile("org.slfj4:slf4j-api:1.7.25")
        //runtime('org.slfj4:slf4j-simple:1.7.26')

}
}

apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.7

repositories {
    maven { url 'http://repo1.maven.org/maven2' }
    //maven { url 'https://mvnrepository.com/artifact/org.slf4j/slf4j-api' }
     }     


dependencies {
    compile('org.springframework.boot:spring-boot-starter-security')
    compile('org.springframework.session:spring-session')
    compile('org.springframework.boot:spring-boot-starter-thymeleaf')
    runtime('org.springframework.boot:spring-boot-devtools')
    compile('org.springframework.boot:spring-boot-starter-data-jpa')
    runtime('org.hsqldb:hsqldb')
    runtime('mysql:mysql-connector-java')
    testCompile('org.springframework.boot:spring-boot-starter-test')
    testCompile('org.springframework.security:spring-security-test')
    testCompile('junit:junit:4.12')
    //
//   Dimensions dependencies
//  
    compile group: 'com.serena', name: 'darius', version:'1.0'
    compile group: 'com.serena', name: 'dmfile', version:'1.0'
    compile group: 'com.serena', name: 'dmnet', version:'1.0'
    compile group: 'com.serena', name: 'dmpmcli', version:'1.0'
    compile group: 'com.serena', name: 'dmclient', version:'1.0'

    // log4j
    compile group: 'log4j', name: 'log4j', version: '1.2.17'

// https://mvnrepository.com/artifact/javax.mail/mail
compile group: 'javax.mail', name: 'mail', version: '1.4.1'

// https://mvnrepository.com/artifact/commons-codec/commons-codec
compile group: 'commons-codec', name: 'commons-codec', version: '1.4'

// https://mvnrepository.com/artifact/javax.inject/javax.inject
compile group: 'javax.inject', name: 'javax.inject', version: '1'

//compile group: 'org.slf4j', name: '

}




task setHttpProxyFromEnv {
    def map = ['HTTP_PROXY': 'http', 'HTTPS_PROXY': 'https']
    for (e in System.getenv()) {
        def key = e.key.toUpperCase()
        if (key in map) {
            def base = map[key]
            def url = e.value.toURL()
            println " - systemProp.${base}.proxy=${url.host}:${url.port}"
            System.setProperty("${base}.proxyHost", url.host.toString())
            System.setProperty("${base}.proxyPort", url.port.toString())
        }
    }
}

build.dependsOn setHttpProxyFromEnv

Я добавил slj4-api и simple в мой classpath, вручную на eclipse, чтобы он работал на eclipse, однако, когда я экспортирую его в исполняемый файл JAR и пытаюсь запустить его из командной строки, он продолжает выскакивать эту ошибку :

Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory

Есть ли команды, которые должны быть запущены в командной строке, или это проблема в eclipse

1 Ответ

1 голос
/ 08 марта 2019

Я вижу, что у вас также есть log4j в вашей зависимости.Означает ли это, что вы пытаетесь использовать slf4j и log4j.

Вот учебник о том, как это сделать: slf4j-with-log4j

Просто вам нужно добавитьэто в вашем gradle.build:

  compile group: 'log4j', name: 'log4j', version: '1.2.17'
  compile group: 'org.slf4j', name: 'slf4j-api', version: '1.7.26'
  compile group: 'org.slf4j', name: 'slf4j-log4j12', version: '1.7.26'

так вы настраиваете каталог вашего проекта Стандартное расположение каталогов

└───maven-project
    ├───pom.xml
    ├───README.txt
    ├───NOTICE.txt
    ├───LICENSE.txt
    └───src
        ├───main
        │   ├───java
        │   └────resources
        │         └───log4j.properties
        └───test
            ├───java
            └───resources

добавьте log4j.properties в ваши ресурсы, это каталог для всех ваших файлов, отличных от Java.

log4j.rootCategory=DEBUG, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yy-MM-dd HH:mm:ss:SSS} %5p %t %c{2}:%L - %m%n

Однако ошибка может быть связана с проблемой обновления обновления.После того, как вы установили свои зависимости, попробуйте синхронизировать gradle и очистить пересобрать ваш проект.

...