8

私はmavenが初めてで、過去2日間、mavenを小さなWebプロジェクトに統合しようとしました。(IDE として Eclipse Juno を使用しています)。最初に、「mvn-archetype-webapp」コマンドで新しいプロジェクト (構造) を生成し、プロジェクトのソースをこの構造にコピーしました。次に、Tomcat7 プラグインを使用してプロジェクトをコンパイルおよび開始できるように、すべての依存関係を pom.xml に追加しました。これまでのところ、すべての maven コマンドの開始時の SLF4J エラー メッセージを除いて、すべて正常に動作します。

    SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". 
    SLF4J: Defaulting to no-operation (NOP) logger implementation SLF4J:
    See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.

私の pom.xml 依存関係は次のようになります。

    <!-- properties -->
    <properties>
        <spring.version>3.1.1.RELEASE</spring.version>
    </properties>

    <!-- dependencies -->   
    <dependencies>

        <!-- logging -->
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.0.6</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.6.6</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>jcl-over-slf4j</artifactId>
            <version>1.6.6</version>
            <scope>runtime</scope>
        </dependency>

        <!-- junit -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>

        <!-- Spring 3 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>${spring.version}</version>
            <exclusions>
                <exclusion>
                    <groupId>commons-logging</groupId>
                    <artifactId>commons-logging</artifactId>
                </exclusion>
            </exclusions>   
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
            <exclusions>
                <exclusion>
                    <groupId>commons-logging</groupId>
                    <artifactId>commons-logging</artifactId>
                </exclusion>
            </exclusions>                       
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>${spring.version}</version>
            <exclusions>
                <exclusion>
                    <groupId>commons-logging</groupId>
                    <artifactId>commons-logging</artifactId>
                </exclusion>
            </exclusions>               
        </dependency>

        <!-- jee -->
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-web-api</artifactId>
            <version>6.0</version>
            <scope>provided</scope>
        </dependency>

        <!-- tiles -->
        <dependency>
            <groupId>org.apache.tiles</groupId>
            <artifactId>tiles-core</artifactId>
            <version>2.2.2</version>
        </dependency>

        <dependency>
            <groupId>org.apache.tiles</groupId>
            <artifactId>tiles-api</artifactId>
            <version>2.2.2</version>
        </dependency>

        <dependency>
            <groupId>org.apache.tiles</groupId>
            <artifactId>tiles-jsp</artifactId>
            <version>2.2.2</version>
        </dependency>

        <!-- jstl -->
        <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
    </dependencies>

誰かがこの問題で私を助けることができますか?

4

7 に答える 7

8

バンドルされている Maven バージョン (m2e) を使用している場合、Eclipse Juno および Indigo はメッセージ SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder" を抑制しません。この動作は、m2e バージョン 1.1.0.20120530-0009 以降から存在します。

ただし、これはエラーとして示されますが、ログは正常に保存されます。強調表示されたエラーは、このバグが修正されるまで引き続き表示されます。詳細については、m2e サポート サイトを参照してください。

現在利用可能な解決策は、バンドルされたバージョンの Eclipse ではなく、外部の Maven バージョンを使用することです。この解決策とこのバグに関する詳細については、以下の質問で確認できます。これは、直面している問題とまったく同じです。

SLF4J: クラス "org.slf4j.impl.StaticLoggerBinder" のロードに失敗しました。エラー

于 2012-11-07T11:10:15.020 に答える
3

同じ問題が発生しています。POMを空のプロジェクトにコピーし、それをほとんどゼロにまで絞り込みました(以下を参照)。それでもエラーが表示されます。SLF4Jバインディング(ログバックなど)をPOMに追加することで、メッセージが消えないことを検証できます。メッセージは、コンパイルおよびテストされているプロジェクトソフトウェアではなく、Maven自体から送信されているようです。(私は今、完全に空のプロジェクトからそれを取得しています。)

私が理解できる最も良いことは、それがEclipseと関係があると思うことです。コマンドラインから手動でMavenを実行すると、エラーは表示されません。Eclipseで呼び出した場合のみです。(私はMacOSXでEclipse Heliosリリース2を使用していますが、参考までに、問題はご使用のバージョンのJunoに限定されないことがわかっています。)

<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>
  <groupId>testing</groupId>
  <artifactId>testing</artifactId>
  <version>0.0.1-SNAPSHOT</version>

</project>

参考までに、Cekiの提案に応えて、Mavenの依存関係ツリーの目標の結果は次のとおりです。

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
[INFO] Scanning for projects...
[INFO]                                                                         
[INFO] ------------------------------------------------------------------------
[INFO] Building testing 0.0.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO] 
[INFO] --- maven-dependency-plugin:2.1:tree (default-cli) @ testing ---
[INFO] testing:testing:jar:0.0.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1.496s
[INFO] Finished at: Thu Oct 04 10:05:41 MDT 2012
[INFO] Final Memory: 9M/81M
[INFO] ------------------------------------------------------------------------

あまり有益ではありませんが、あります。

于 2012-07-06T19:47:31.300 に答える
3

このエラーは、プロジェクトからではなく、Maven を実行している Eclipse から発生するため、ビルド プロセスや結果のファイルには影響しません。

これは、slf4j や別のロギング ツールではなく、Eclipse または Maven プラグインが試みている Maven に関連する問題だと思います。

エラーを取り除く最も簡単な方法は、Eclipse でランタイムの代わりに外部 Maven を使用することです。これは、Preferences -> Maven -> Installations で構成できます。

于 2012-07-14T09:30:23.293 に答える
1

依存関係の宣言はよさそうです。Logback と slf4j は、Web アプリで配布されます。ただし、slf4j-api.jar が何らかの理由で Tomcat に含まれていると思われます (logback には含まれません)。

ところで、mvn dependency:treeコマンドはあなたの友達です。それは何と言っていますか?

于 2012-07-06T07:52:22.627 に答える
0

「tomcat7 プラグインを使用」

tomcat7 プラグインには SLF4J 依存関係があります。依存関係を tomcat7 プラグインに直接割り当てるまで、同じ問題がありました。

<pluginManagement>
<plugins>
   <plugin>
        <groupId>org.apache.tomcat.maven</groupId>
        <artifactId>tomcat7-maven-plugin</artifactId>
        <version>2.2</version>
        <dependencies>
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-simple</artifactId>
                <version>1.7.5</version>
            </dependency>                    
        </dependencies>
        <configuration>
            <!-- ...snip... -->
        </configuration>
    </plugin>
</plugins>
</pluginManagement>
于 2014-06-01T21:39:02.543 に答える
0

logback-core の依存関係を追加してみてください。

    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
        <version>1.0.6</version>
        <scope>runtime</scope>
    </dependency>
于 2012-07-05T18:19:33.127 に答える