0

これに続いてjettyでログバックアクセスを使用しようとしていますが 、サーバーの起動時にこの例外が発生します:

| での構成エラー 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 プラグインを使用しているので、次のようになります。

jetty プラグインに依存関係を追加しましたか?:

<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 に答える