我越来越关注SLF4J异常,我试过从pom.xml中删除slf4j依赖关系,仍然存在,任何人都可以帮忙?如何解决这个slf4j异常,未找到日志方法
例外情况如下: 。 。 。
" org.osgi.framework.BundleException: Exception in oracle.acs.assessment.PatchDataExtractionActivator.start() of bundle oracle.acs.mf.PatchDataExtractionBundle. at org.eclipse.osgi.framework.internal.core.BundleContextImpl.startActivator(BundleContextImpl.java:1018) > at org.eclipse.osgi.framework.internal.core.BundleContextImpl.start(BundleContextImpl.java:974) > at org.eclipse.osgi.framework.internal.core.BundleHost.startWorker(BundleHost.java:346) > at org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:260) > at org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:252) > at org.eclipse.osgi.framework.internal.core.FrameworkCommandProvider._start(FrameworkCommandProvider.java:260) > at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) > at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) > at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.lang.reflect.Method.invoke(Method.java:606) > at org.eclipse.osgi.framework.internal.core.FrameworkCommandInterpreter.execute(FrameworkCommandInterpreter.java:150) > at org.eclipse.osgi.framework.internal.core.FrameworkConsole.docommand(FrameworkConsole.java:291) > at org.eclipse.osgi.framework.internal.core.FrameworkConsole.console(FrameworkConsole.java:276) > at com.sun.svc.container.admin.cli.Console.run(Console.java:85) > at java.lang.Thread.run(Thread.java:724) Caused by: java.lang.NoSuchMethodError: > org.slf4j.spi.LocationAwareLogger.log(Lorg/slf4j/Marker;Ljava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V > at org.apache.log4j.Category.log(Category.java:288) > at org.apache.commons.logging.impl.Log4JLogger.info(Log4JLogger.java:199) > at org.springframework.context.support.AbstractApplicationContext.prepareRefresh(AbstractApplicationContext.java:412) > at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:350) > at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139) > at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:93) > at oracle.acs.assessment.util.SpringHelper.initContext(SpringHelper.java:34) > at oracle.acs.assessment.util.SpringHelper.getBean(SpringHelper.java:57) > at oracle.acs.assessment.PatchDataExtractionActivator.start(PatchDataExtractionActivator.java:50) > at org.eclipse.osgi.framework.internal.core.BundleContextImpl$2.run(BundleContextImpl.java:999) > at java.security.AccessController.doPrivileged(Native Method) > at org.eclipse.osgi.framework.internal.core.BundleContextImpl.startActivator(BundleContextImpl.java:993) > ... 14 more Nested Exception: java.lang.NoSuchMethodError:
org.slf4j.spi.LocationAwareLogger.log(Lorg/SLF4J /标记; Ljava /郎/字符串; ILjava /郎/字符串; Ljava /郎/ Throwable的;)V
at org.apache.log4j.Category.log(Category.java:288) at org.apache.commons.logging.impl.Log4JLogger.info(Log4JLogger.java:199) at org.springframework.context.support.AbstractApplicationContext.prepareRefresh(AbstractApplicationContext.java:412) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:350) at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139) at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:93) at oracle.acs.assessment.util.SpringHelper.initContext(SpringHelper.java:34) at oracle.acs.assessment.util.SpringHelper.getBean(SpringHelper.java:57) at oracle.acs.assessment.PatchDataExtractionActivator.start(PatchDataExtractionActivator.java:50) at org.eclipse.osgi.framework.internal.core.BundleContextImpl$2.run(BundleContextImpl.java:999) at java.security.AccessController.doPrivileged(Native Method) at org.eclipse.osgi.framework.internal.core.BundleContextImpl.startActivator(BundleContextImpl.java:993) at org.eclipse.osgi.framework.internal.core.BundleContextImpl.start(BundleContextImpl.java:974) at org.eclipse.osgi.framework.internal.core.BundleHost.startWorker(BundleHost.java:346) at org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:260) at org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:252) at org.eclipse.osgi.framework.internal.core.FrameworkCommandProvider._start(FrameworkCommandProvider.java:260) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) at org.eclipse.osgi.framework.internal.core.FrameworkCommandInterpreter.execute(FrameworkCommandInterpreter.java:150) at org.eclipse.osgi.framework.internal.core.FrameworkConsole.docommand(FrameworkConsole.java:291) at org.eclipse.osgi.framework.internal.core.FrameworkConsole.console(FrameworkConsole.java:276) at com.sun.svc.container.admin.cli.Console.run(Console.java:85) at java.lang.Thread.run(Thread.java:724) Nested Exception: java.lang.NoSuchMethodError:
org.slf4j.spi.LocationAwareLogger.log(Lorg/SLF4J /标记; Ljava /郎/字符串; ILjava /郎/字符串; Ljava /郎/ Throwable的)在org.apache.log4j.Category V 。日志(Category.java:288) at org.apache.commons.logging.impl.Log4JLogger.info(Log4JLogger.java:199) at org.springframework.context.support.AbstractApplicationContext.prepareRefresh(AbstractApplicationContext.java:412) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:350) at org.springframework.context.support。 ClassPathXmlApplicationContext的。(ClassPathXmlApplicationContext.java:139) 在org.springframework.context.support.ClassPathXmlApplicationContext。(ClassPathXmlApplicationContext.java:93) 在oracle.acs.assessment.util.SpringHelper.initContext(SpringHelper.java:34) 在oracle.acs.assessment.util.SpringHelper.getBean(SpringHelper.java:57) at oracle.acs.assessment.PatchDataExtractionActivator.start(PatchDataExtractionActivator.java:50) at org.eclipse.osgi.framework.internal .core.BundleContextImpl $ 2.run(BundleContextImpl.java:999) at java.security.AccessController.doPrivileged(Native Method) at org.eclipse.osgi.framework.internal.core.BundleContextImpl.startActivator(BundleContextImpl.java:993 )org.eclipse.osgi.framework.internal.core.BundleHost.startWorker(BundleHost.java:346) 在org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:260) at org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:252) at org .eclipse.osgi.framework.internal.core.FrameworkCommandProvider._start(FrameworkCommandProvider.java:260) at sun.reflect.Nativ eMethodAccessorImpl.invoke0(本机方法) 在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在java.lang.reflect.Method.invoke (Method.java:606) at org.eclipse.osgi.framework.internal.core.FrameworkCommandInterpreter.execute(FrameworkCommandInterpreter.java:150) at org.eclipse.osgi.framework.internal.core.FrameworkConsole.docommand(FrameworkConsole .java:291) at org.eclipse.osgi.framework.internal.core.FrameworkConsole.console(FrameworkConsole.java:276) at com.sun.svc.container.admin.cli.Console.run(Console.java :85) at java.lang.Thread.run(Thread。Java的:724)
我的POM文件是
<?xml version="1.0" encoding="UTF-8"?>
<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>
<parent>
<groupId>oracle.acs.mf</groupId>
<artifactId>assessment</artifactId>
<version>all</version>
<relativePath>../pom.xml</relativePath>
</parent>
<groupId>oracle.acs.mf</groupId>
<artifactId>PatchDataExtractionBundle</artifactId>
<version>${assmnt.version}</version>
<packaging>bundle</packaging>
<name>Sun IT Services :: Monitoring Framework :: PatchDataExtractionBundle Bundle</name>
<description>PatchDataExtractionBundle OSGi bundle project.</description>
<properties>
<slf4j.version>1.6.1</slf4j.version>
<logback.version>1.0.11</logback.version>
</properties>
<dependencies>
<dependency>
<groupId>com.sun.cs</groupId>
<artifactId>transport</artifactId>
<version>2.5.6</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.sun.mf</groupId>
<artifactId>MonitoringFrameworkBundle</artifactId>
<version>3.0-SNAPSHOT</version>
<!--<scope>provided</scope>-->
<scope>compile</scope>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>oracle.acs.platform</groupId>
<artifactId>MonitoringFrameworkBundle</artifactId>
<!--<version>all</version>-->
<version>3.5.999</version>
<type>jar</type>
<scope>compile</scope>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>2.5.4</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring</artifactId>
<version>2.5.4</version>
<type>jar</type>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.osgi</groupId>
<artifactId>org.osgi.core</artifactId>
<version>4.2.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.karaf.shell</groupId>
<artifactId>org.apache.karaf.shell.console</artifactId>
<version>2.2.3</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>oracle.jdbc</groupId>
<artifactId>ojdbc14</artifactId>
<version>10.1.0.5.0</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.eclipse</groupId>
<artifactId>osgi</artifactId>
<version>3.5.0.v20090520</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>${logback.version}</version>
<optional>true</optional>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>${logback.version}</version>
<optional>true</optional>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>oracle.acs.mf</groupId>
<artifactId>assessment-common</artifactId>
<version>2.1</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>commons-dbcp</groupId>
<artifactId>commons-dbcp</artifactId>
<version>1.2.2</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-io</artifactId>
<version>1.3.2</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.1</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<version>2.3.7</version>
<extensions>true</extensions>
<configuration>
<instructions>
<Bundle-Name>${project.groupId}.${project.artifactId}</Bundle-Name>
<Bundle-SymbolicName>${project.groupId}.${project.artifactId}</Bundle-SymbolicName>
<Bundle-Version>${project.version}</Bundle-Version>
<Bundle-Activator>oracle.acs.assessment.PatchDataExtractionActivator</Bundle-Activator>
<Embed-Dependency>*;scope=compile|runtime</Embed-Dependency>
<!-- include the complete set of transitive dependencies -->
<Embed-Transitive>true</Embed-Transitive>
<Embed-Directory>META-INF/lib</Embed-Directory>
<!-- Custom entries
<CONFIG_FILE>/${install.config.dir}/patch_assessment.properties</CONFIG_FILE>-->
<Export-Package>
oracle.acs.assessment.service.*;oracle.acs.assessment.entity.*;version=${project.version}
</Export-Package>
<Import-Package>
org.osgi.service.http,
org.osgi.framework;version="1.3.0",
org.eclipse.osgi.framework.console, *;resolution:=optional
</Import-Package>
</instructions>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
答案取决于你想要做什么。你想使用slf4j进行日志记录吗?如果是这样,删除它是相当适得其反。显然你的一个依赖使用apache commons logging,但是找不到它的实现。所以*如果你想通过slf4j/logback登录,你必须添加你在你的pom中排除的jcl-over-slf4j依赖。它确保所有jcl事件都通过slf4j进行路由。 – sheltem
是的,我想使用slf4j进行日志记录,因为我得到的错误,该方法没有发现异常,所以我冲浪了互联网,发现错误可能是由于slf4j的多个依赖项,所以我排除所有依赖项slf4j,我仍然我得到这个错误。 我有以下的疑问,你可以请澄清.. 因为我想使用slf4j进行日志记录,我也加入了依赖,但由于我得到异常可能是由于多个slf4j版本依赖关系,我认为其他依赖正在下载。我应该排除其他依赖或不? – Shivagoy
Hi Sheltem, 你能帮我解决这个异常吗?因为我被这个异常严重困住了。 – Shivagoy