私は、依存するすべての依存関係から除外することなく、推移的な依存関係を除外する「一般的な」方法を見つけようとしています。たとえば、slf4jを除外する場合、次のようにします。
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-jmx</artifactId>
<version>3.3.2.GA</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>3.4.0.GA</version>
<type>jar</type>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
これは、一部はpomファイルをクリーンアップすること、一部はその除外された依存関係に依存する依存関係を追加し、除外することを忘れるという問題を将来回避するためです。
方法はありますか?
これは役立ちますか? http://jlorenzen.blogspot.com/2009/06/maven-global-excludes.html
「アバロンフレームワークをWARから除外すると仮定すると、提供されるスコープでプロジェクトPOMに以下を追加します。これは、すべての推移的な依存関係で機能し、一度指定することができます。
<dependencies>
<dependency>
<artifactId>avalon-framework</artifactId>
<groupId>avalon-framework</groupId>
<version>4.1.3</version>
<scope>provided</scope>
</dependency>
</dependencies>
これは、親POMで指定する場合でも機能し、すべての子POMでプロジェクトを宣言する必要がなくなります。」
空のjarを作成し、この依存関係を作成しました。
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<scope>system</scope>
<systemPath>${basedir}/src/lib/empty.jar</systemPath>
<version>0</version>
</dependency>
コンパイル/テストパスに空のjarがあるため、これは完全ではありません。しかし、それは単なる見た目です。
dnaultのコメント を展開するには:
Maven Enforcerプラグインの禁止された依存関係ルール を使用して、依存関係を確実に除外できます。手動でそれらを除外する必要がありますが、誰かが誤って依存関係を他の場所に追加した場合、ビルドは失敗します。
<dependencies>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-jmx</artifactId>
<version>3.3.2.GA</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<plugins>
<plugin>
<groupId>org.Apache.maven.plugins</groupId>
<artifactId>maven-enforcer-plugin</artifactId>
<version>1.4.1</version>
<executions>
<execution>
<goals>
<goal>enforce</goal>
</goals>
<configuration>
<rules>
<bannedDependencies>
<excludes>
<exclude>org.slf4j:slf4j-api</exclude>
</excludes>
</bannedDependencies>
</rules>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
また、オープン機能のリクエストがあります: MNG-1977グローバル依存関係の除外
念のため、Mavenの公式ドキュメントからの回答を次に示します。
POMレベルではなく、依存関係ごとに除外が行われる理由
これは主に、依存関係グラフが予測可能であることを確認し、継承効果が除外されるべきではない依存関係を除外しないようにするために行われます。最終手段に到達し、除外する必要がある場合は、どの依存関係がその望ましくない推移的な依存関係をもたらしているかを完全に確認する必要があります。
ビルドをより堅牢にしたい場合は、バージョン範囲を使用できます。これにより、依存関係の新しいバージョンがプロジェクトに干渉することがなくなります。
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>[1.4.2,)</version>
<scope>provided</scope>
</dependency>
すべてのslf4j-apiバージョン> = 1.4.2は、構成されたクラスパスまたはコンテナのいずれかから、実行時に提供(提供)されると見なされます。
参考文献