Maven Java интеграция - PullRequest
0 голосов
/ 26 июня 2018

Вот простой Java-код с SL4J , созданный с помощью Maven. Следующие команды не имеют проблем. Все они работают хорошо mvn compile мвн пакет mvn clean install mvn exec: java

Но когда я пытаюсь выполнить любое из следующих действий

java -cp target/MaventestApp-1.0-SNAPSHOT.jar com.maven.helloworld.App
jar tf ./target/MaventestApp-1.0-SNAPSHOT.jar

Я получаю следующую ошибку

    exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
        at com.maven.helloworld.App.main(App.java:17)
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
        at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)

Вот соответствующая часть моего pom.xml файла:

<properties>
  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  <maven.compiler.source>1.7</maven.compiler.source>
  <maven.compiler.target>1.7</maven.compiler.target>
  <slf4jVersion>1.6.1</slf4jVersion>
</properties>

<dependencies>
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.11</version>
    <scope>test</scope>
  </dependency>
  <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-simple</artifactId>
    <version>${slf4jVersion}</version>
  </dependency>
  <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>${slf4jVersion}</version>
  </dependency>
</dependencies>

<build>
  <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
    <plugins>
      <plugin>
        <artifactId>maven-clean-plugin</artifactId>
        <version>3.0.0</version>
      </plugin>
      <!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
      <plugin>
        <artifactId>maven-resources-plugin</artifactId>
        <version>3.0.2</version>
      </plugin>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.7.0</version>
      </plugin>
      <plugin>
        <artifactId>maven-surefire-plugin</artifactId>
        <version>2.20.1</version>
      </plugin>
      <plugin>
        <artifactId>maven-jar-plugin</artifactId>
        <version>3.0.2</version>
        <configuration>
          <archive>
            <manifest>
              <addClasspath>true</addClasspath>
              <mainClass>com.maven.helloworld.App</mainClass>
            </manifest>
          </archive>
        </configuration>
      </plugin>
      <plugin>
        <artifactId>maven-install-plugin</artifactId>
        <version>2.5.2</version>
      </plugin>
      <plugin>
        <artifactId>maven-deploy-plugin</artifactId>
        <version>2.8.2</version>
      </plugin>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>exec-maven-plugin</artifactId>
        <version>1.2.1</version>
        <executions>
          <execution>
            <goals>
              <goal>java</goal>
            </goals>
          </execution>
        </executions>
        <configuration>
          <mainClass>com.maven.helloworld.App</mainClass>
        </configuration>
      </plugin>
    </plugins>
  </pluginManagement>
</build>

Код для этого образца здесь

Может кто-нибудь помочь мне лучше понять maven и процесс исполнения? Цените свое время.

Ответы [ 2 ]

0 голосов
/ 26 июня 2018

Проблема в том, как вы строите свой JAR-файл (зависимости в него не входят). Вместо этого вы можете использовать maven-assembly-plugin (см. Различия между сборкой и jar-плагином здесь ).

В основном замените текущий раздел сборки следующим:

<build>
  <plugins>
    <plugin>
      <artifactId>maven-assembly-plugin</artifactId>
      <configuration>
        <archive>
          <manifest>
            <mainClass>com.maven.helloworld.App</mainClass>
          </manifest>
        </archive>
        <descriptorRefs>
          <descriptorRef>jar-with-dependencies</descriptorRef>
        </descriptorRefs>
      </configuration>
      <executions>
        <execution>
          <id>make-assembly</id>
          <phase>package</phase>
          <goals>
            <goal>single</goal>
          </goals>
        </execution>
      </executions>
    </plugin>
  </plugins>
</build>

Затем выполните сгенерированный jar-with-dependencies, используя следующую команду:

java -jar target/MaventestApp-1.0-SNAPSHOT-jar-with-dependencies.jar

Подробнее о создании исполняемых JAR-файлов здесь .

0 голосов
/ 26 июня 2018

Существует Exec Maven Plugin , который должен делать эту работу. Что-то вроде

mvn exec:java -Dexec.mainClass=com.maven.helloworld.App

Фактическая проблема заключается в том, что вы добавляете свой jar-файл только в classpath, и поскольку у вас нет sl4j-классов в вашем собственном архиве, но вы объявили их как внешнюю зависимость, они просто отсутствуют (или NoClassDefFoundError).

Команда выше связывает все зависимости времени выполнения с classpath, как настроено в pom.

...