Есть ли способ исключить зависимость Maven во всем мире? - PullRequest
76 голосов
/ 17 января 2011

Я пытаюсь найти «общий» способ исключения транзитивной зависимости от включения без необходимости исключать ее из всех зависимостей, которые от нее зависят. Например, если я хочу исключить 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, частично для избежания проблем в будущем, когда люди добавляют зависимости, которые зависят от этой исключенной зависимости, и забывают исключить ее.

Есть ли способ?

Ответы [ 4 ]

56 голосов
/ 17 января 2011

Это помогает? http://jlorenzen.blogspot.com/2009/06/maven-global-excludes.html

"Предполагая, что я хочу исключить avalon-framework из моей WAR, я бы добавил следующее в POM своих проектов с указанным объемом. Это работает для всех переходных зависимостей и позволяет указать его один раз.

<dependencies>
  <dependency>
      <artifactId>avalon-framework</artifactId>
      <groupId>avalon-framework</groupId>
      <version>4.1.3</version>
      <scope>provided</scope>
  </dependency>
</dependencies>

Это работает даже при указании его в родительском POM, что не позволяет проектам объявлять это во всех дочерних POM. "

16 голосов
/ 27 июня 2013

Я создал пустой 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 на пути компиляции / тестирования.Но это просто косметика.

9 голосов
/ 07 сентября 2017

Чтобы развернуть комментарий 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 Глобальные исключения зависимостей

4 голосов
/ 11 октября 2016

Напоминаем, что ответ от официальной документации 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 будет считаться предложенной (предоставленной) во время выполнения, либоиз настроенного пути к классу или контейнера.

Ссылки

...