java.lang.ClassNotFoundException: org.apache.log4j.Level

Я пытаюсь использовать hibernate 3.5.1 final в приложении Swing, и вот банки, которые я использую:

  • hibernate-core-3.5.1-Final
  • hibernate-entitymanager-3.5.1-Final
  • hibernate-jpa-2.0-api-1.0.0.Final
  • hibernate-annotations-3.5.1-Final
  • hibernate-commons-annotations-3.2.0.Final
  • dom4j-1.6.1
  • slf4j-api-1.6.4
  • slf4j-log4j12-1.6.4

Когда я пытаюсь запустить приложение, я получаю следующую ошибку:

Failed to instantiate SLF4J LoggerFactory
Reported exception:
java.lang.NoClassDefFoundError: org/apache/log4j/Level
    at org.slf4j.LoggerFactory.bind(LoggerFactory.java:128)
    at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:108)
    at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:279)
    at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:252)
    at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:265)
    at org.hibernate.cfg.Configuration.<clinit>(Configuration.java:165)
    at org.hibernate.ejb.Ejb3Configuration.<clinit>(Ejb3Configuration.java:127)
    at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:54)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:48)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:32)
    at com.xeno.xecamp.desktopManagement.Main.main(Main.java:16)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Level
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
    ... 11 more
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Level
    at org.slf4j.LoggerFactory.bind(LoggerFactory.java:128)
    at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:108)
    at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:279)
    at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:252)
    at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:265)
    at org.hibernate.cfg.Configuration.<clinit>(Configuration.java:165)
    at org.hibernate.ejb.Ejb3Configuration.<clinit>(Ejb3Configuration.java:127)
    at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:54)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:48)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:32)
    at com.xeno.xecamp.desktopManagement.Main.main(Main.java:16)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Level
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:248)

person Mahmoud Saleh    schedule 14.05.2012    source источник
comment
Если вы пытаетесь использовать символические ссылки для прикрепления файлов jar, см. stackoverflow.com/questions/22240776/   -  person GlenPeterson    schedule 17.10.2014


Ответы (3)


Вам также необходимо включить JAR-файл Log4J в путь к классам.

Обратите внимание, что slf4j-log4j12-1.6.4.jar - это всего лишь адаптер, позволяющий использовать Log4J через SLF4J API. Он не содержит фактической реализации Log4J.

person Jesper    schedule 14.05.2012
comment
Подскажите, пожалуйста, зависимость maven, совместимую с версией, которую я использую? - person Mahmoud Saleh; 14.05.2012
comment
ну мне просто нужен log4j-1.2.16.jar - person Mahmoud Saleh; 14.05.2012
comment
добавление log4j-1.2.16.jar также решило проблему в моем случае, но slf4j-log4j12-1.6.4.jar не сделал - person lizzie; 26.07.2013
comment
на самом деле добавления зависимости maven как таковой в моем случае было недостаточно, мне также пришлось добавить флаг: ‹scope› build ‹/scope›, чтобы он запускался: ‹dependency› ‹groupId› log4j ‹/groupId› ‹artifactId› log4j ‹ / artifactId ›‹version› 1.2.17 ‹/version› ‹scope› build ‹/scope› ‹/dependency› - person Macilias; 25.11.2015

Вам необходимо загрузить log4j и добавить в свой путь к классам.

person elias    schedule 14.05.2012

В своей среде я просто добавил два файла в путь к классу. И работает нормально.

slf4j-jdk14-1.7.25.jar
slf4j-api-1.7.25.jar
person wenchunl    schedule 21.05.2018
comment
Спасибо, у меня это сработало в октябре 2019 года. Мне даже log jar не понадобилась, slf4j-jdk об этом позаботился. - person Azurespot; 31.10.2019