0

我正在尝试在之后使用码头的 logback 访问 但是我在启动服务器时遇到了这个异常:

配置错误 | logback.xml | java.lang.ClassNotFoundException: ch.qos.logback.access.jetty.RequestLogImpl

这是 jetty.xml 中导致问题的代码:

<Ref id="RequestLogHandler">
 <Set name="requestLog">
    <New id="requestLogImpl" class="ch.qos.logback.access.jetty.RequestLogImpl">
       <Set name="resource">as/classpath/resource/myaccess.xml</Set>
    </New>   
  </Set>
</Ref>

这是 pom.xml

<dependencies>      
<dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.0.1</version>
        <scope>provided</scope>
    </dependency>
  <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-access</artifactId>
        <version>1.0.13</version>
      </dependency>
      <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
        <version>1.0.13</version>
      </dependency>
  </dependencies>
 <build>
<finalName>oslc4j-jira-sample</finalName>
    <plugins>


    <plugin>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>jetty-maven-plugin</artifactId>


        <configuration>
            <webAppConfig>
              <contextPath>/OSLC4JJira</contextPath>
            </webAppConfig>
              <!-- Jetty config adds logging -->
            <jettyConfig>${project.build.directory}/classes/jetty.xml</jettyConfig>

            <!-- enable hot deploy -->
            <reload>automatic</reload>
            <scanIntervalSeconds>5</scanIntervalSeconds>
            <scanTargets>
                <scanTarget>WebContent</scanTarget>
            </scanTargets>
                   <systemProperties>

                <systemProperty>
                    <name>config.dir</name>
                    <value>${basedir}/src/test/resources</value>
                </systemProperty>

                <systemProperty>
                    <name>jetty.logs</name>
                    <value>${basedir}/target</value>
                </systemProperty>
                <systemProperty>
                    <name>jetty.port</name>
                    <value>8080</value>
                </systemProperty>

            </systemProperties>
            <webResources>
        <resource>
          <directory>${build.sourceDirectory}</directory>
          <targetPath>sources</targetPath>
        </resource>
       </webResources>
<dependencies>
   <dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.0.13</version>
      </dependency>
</dependencies>
    </configuration>
    </plugin>
</plugins>

4

2 回答 2

0

正如 user2878524 所说,这是这里的错误链接

于 2013-10-17T16:44:18.043 回答
0

您通常必须这样做:“下载 logback 发行版后,将文件 logback-core-VERSION.jar 和 logback-access-VERSION.jar 放在 $JETTY_HOME/lib 目录下,其中 $JETTY_HOME 是您安装 Jetty 的文件夹. logback-access 0.9.31 及更高版本针对 Jetty 7.x 和 8.x 版本。Logback-access 0.9.30 及更早版本针对 Jetty 6.x 版本。” 但是您使用的是 jetty maven 插件,所以:

您是否在码头插件中添加了依赖项?:

<project>
  ...
  <build>
    ...
    <plugins>
      ...
      <plugin>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>jetty-maven-plugin</artifactId>
        <version>8.0.4.v20111024</version><!-- or whatever version you specified -->
        <configuration>
          ...
        </configuration>
        ...
          <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.0.13</version>
          </dependency>
        ...
      </plugin>
      ...
    </plugins>
    ...
  </build>
  ...
</project>
于 2013-10-14T10:52:11.493 回答