Подтвердить что ты не робот

Предупреждение плагина Maven shade: у нас есть дубликат - как исправить?

Это мой проект POM (ссылка на пасту, поэтому вы можете щелкнуть правой кнопкой мыши > сохранить как pom.xml)

<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>com.zybnet</groupId>
    <artifactId>excel-reporter</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>mvn1</name>
    <url>http://maven.apache.org</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.8</version>
        </dependency>
        <dependency>
            <groupId>net.sf.jasperreports</groupId>
            <artifactId>jasperreports</artifactId>
            <version>4.6.0</version>
        </dependency>
        <dependency>
            <groupId>org.codehaus.groovy</groupId>
            <artifactId>groovy-all</artifactId>
            <version>2.0.0</version>
        </dependency>
    </dependencies>

    <build>
        <resources>
            <resource>
                <directory>${project.build.sourceDirectory}</directory>
            </resource>
        </resources>
        <plugins>
            <plugin>
                <artifactId>maven-jar-plugin</artifactId>
                <configuration>
                    <finalName>${artifactId}-${version}-tmp</finalName>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>1.7.1</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <filters>
                                <filter>
                                    <artifact>*:*</artifact>
                                    <excludes>
                                        <exclude>META-INF/*.SF</exclude>
                                        <exclude>META-INF/*.DSA</exclude>
                                        <exclude>META-INF/*.RSA</exclude>
                                    </excludes>
                                </filter>
                            </filters>
                            <transformers>
                                <transformer
                                    implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>com.zybnet.Main</mainClass>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

Я следил за советом по настройке плагина jar по умолчанию, как описано в часто задаваемых вопросов, но все же, когда я запускаю mvn package около 20 тыс. предупреждений выдаются. Выполнение mvn clean тоже не помогает.

В соответствии с этим ответом я могу вручную исключить некоторые зависимости. Тем не менее, я не знаю, правильно ли это, и дерево зависимостей довольно сложно, поэтому трудно спорить, с чего начать.

Я знаю, что эти проблемы не являются вредными, но я привык относиться к предупреждениям как к чему-то, что должно быть исправлено. Более того, я новичок в Maven, поэтому я хотел бы понять, что не так с моим пониманием и как устранить проблемы.

(Использование плагина сборки maven здесь не вариант)

4b9b3361

Ответ 1

Иногда бывает, что одно и то же определение класса находится в двух или более JAR файлах (обычно это JAR-устройства зависимостей). В этом случае разработчик ничего не может сделать, кроме как попытаться выяснить, что вручную исключить из зависимостей или из финального артефакта (возможно, с помощью mvn dependency:tree -Ddetail=true). я открыла проблему и отправила исправление, чтобы помочь разработчику получить немного более красивый результат, например

[WARNING] xml-apis-1.3.02.jar, xmlbeans-2.3.0.jar define 4 overlappping classes:
[WARNING]   - org.w3c.dom.TypeInfo
[WARNING]   - org.w3c.dom.DOMConfiguration
[WARNING]   - org.w3c.dom.DOMStringList
[WARNING]   - org.w3c.dom.UserDataHandler
[WARNING] maven-shade-plugin has detected that some .class files
[WARNING] are present in two or more JARs. When this happens, only
[WARNING] one single version of the class is copied in the uberjar.
[WARNING] Usually this is not harmful and you can skip these
[WARNING] warnings, otherwise try to manually exclude artifacts
[WARNING] based on mvn dependency:tree -Ddetail=true and the above
[WARNING] output
[WARNING] See http://docs.codehaus.org/display/MAVENUSER/Shade+Plugin

Используя этот вывод, а из mvn dependency:tree, я добавил разделы, такие как

<dependency>
    <groupId>net.sf.jasperreports</groupId>
    <artifactId>jasperreports</artifactId>
    <version>4.7.0</version>
    <exclusions>
        <exclusion>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
        </exclusion>
        <exclusion>
            <groupId>bouncycastle</groupId>
            <artifactId>bcmail-jdk14</artifactId>
        </exclusion>
        <exclusion>
            <groupId>bouncycastle</groupId>
            <artifactId>bcprov-jdk14</artifactId>
        </exclusion>
        <exclusion>
            <groupId>org.bouncycastle</groupId>
            <artifactId>bctsp-jdk14</artifactId>
        </exclusion>
    </exclusions>
</dependency>

и удалось уменьшить количество предупреждений от нескольких тысяч до нескольких десятков. Тем не менее, это не идеально. Тем не менее, они продолжают копировать классы, которые приводят к конфликтам имен (я не могу понять, почему). Тем не менее, это решение специфично для этого конкретного проекта и не может быть легко перенесено на что-либо еще.

Ответ 2

Поскольку новое обновление этой проблемы обновляется до текущего плагина maven. Вопрос заключается в использовании

<version>1.7.1</version>

который только скажет вам, что вы:

We have a duplicate org/eclipse/persistence/internal/libraries/asm/AnnotationVisitor.class in /Users/.../repository/org/eclipse/persistence/eclipselink/2.7.0/eclipselink-2.7.0.jar

Оставив вас угадать или проб и ошибок, где первая запись, в которой у вас есть перекрывающиеся классы. Не очень полезно. Fortunatly,

 <version>3.1.0</version>

предоставит вам более полезный результат, который включает в себя банки, откуда они пришли: например

annotations-3.0.1.jar, jcip-annotations-1.0.jar define 4 overlapping classes: 
  - net.jcip.annotations.GuardedBy
  - net.jcip.annotations.NotThreadSafe
  ...

Затем вы можете решить исключить тот или другой или использовать тень для переименования классов в соответствии с вашим проектом.