Java 11 без модульности: пакет не существует, пока он добавлен как зависимость maven

#java #eclipse #maven #spring-boot #java-11

#java #eclipse #maven #spring-boot #java-11

Вопрос:

У меня есть три очень простых приложения. Один из них ОБЩИЙ, в котором я сосредоточу настройки безопасности, другой с функцией ZUUL, а третий — СЕРВЕР EUREKA. Оба являются Spring Boot и Java 11. Хотя я использую Java 11, я не полагаюсь на модульность (насколько я знаю, не имеет смысла использовать функцию модульности при загрузке Spring).

Когда я запускаю все три в Eclipse, я успешно могу запустить сервер, common и zuul в этой последовательности. При попытке сборки maven я получаю ошибку, упомянутую в теме.

Немедленным объяснением было бы «у вас нет общего в zuul classpath». Ну, насколько я проверяю, у меня есть общий путь к классу zuul. Мне интересно, есть ли какая-либо дополнительная конфигурация, потому что я использую Java 11, но не использую modularaty.

Говоря, что я использую Java 11, но не модульность, я имею в виду, что у меня есть Java 11, но у меня нет module-info.java вообще ни в одном из трех проектов.

Проверяем папку .m2 и распаковываем common.jar Я вижу, что класс пожаловался.

Zuul project pom:

 <?xml version="1.0" encoding="UTF-8"?>
<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>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.3.RELEASE</version>
        <relativePath /> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.test</groupId>
    <artifactId>zuul</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>zuul</name>
    <description>Zuul project</description>

    <properties>
        <java.version>11</java.version>
        <spring-cloud.version>Greenwich.SR1</spring-cloud.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <!-- https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt -->
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt</artifactId>
            <version>0.9.1</version>
        </dependency>

        <dependency>
            <groupId>com.test</groupId>
            <artifactId>common</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
  

Доказательством того, что распространенными являются зависимости maven

введите описание изображения здесь

Ошибка при чистой установке mvn:

 [INFO] Scanning for projects...
[INFO] 
[INFO] ---------------------------< com.test:zuul >----------------------------
[INFO] Building zuul 0.0.1-SNAPSHOT
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- maven-resources-plugin:3.1.0:resources (default-resources) @ zuul ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 1 resource
[INFO] Copying 0 resource
[INFO] 
[INFO] --- maven-compiler-plugin:3.8.0:compile (default-compile) @ zuul ---
[INFO] Changes detected - recompiling the module!
[INFO] Compiling 2 source files to C:_dWSssotestezuultargetclasses
[INFO] -------------------------------------------------------------
[ERROR] COMPILATION ERROR : 
[INFO] -------------------------------------------------------------
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[14,32] package com.test.common.security does not exist
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[21,17] cannot find symbol
  symbol:   class JwtConfig
  location: class com.test.zuul.security.SecurityTokenConfig
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[46,16] cannot find symbol
  symbol:   class JwtConfig
  location: class com.test.zuul.security.SecurityTokenConfig
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[47,23] cannot find symbol
  symbol:   class JwtConfig
  location: class com.test.zuul.security.SecurityTokenConfig
[INFO] 4 errors 
[INFO] -------------------------------------------------------------
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 4.778 s
[INFO] Finished at: 2019-03-21T14:23:23-03:00
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.0:compile (default-compile) on project zuul: Compilation failure: Compilation failure: 
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[14,32] package com.test.common.security does not exist
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[21,17] cannot find symbol
[ERROR]   symbol:   class JwtConfig
[ERROR]   location: class com.test.zuul.security.SecurityTokenConfig
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[46,16] cannot find symbol
[ERROR]   symbol:   class JwtConfig
[ERROR]   location: class com.test.zuul.security.SecurityTokenConfig
[ERROR] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java:[47,23] cannot find symbol
[ERROR]   symbol:   class JwtConfig
[ERROR]   location: class com.test.zuul.security.SecurityTokenConfig
[ERROR] -> [Help 1]
[ERROR] 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException
  

Класс, на который жаловались, находится в jar

введите описание изображения здесь

*** Отредактировано

Обычный pom

 <?xml version="1.0" encoding="UTF-8"?>
<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>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.3.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.test</groupId>
    <artifactId>common</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>common</name>
    <description>Zuul project</description>

    <properties>
        <java.version>11</java.version>
        <spring-cloud.version>Greenwich.SR1</spring-cloud.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
  

Комментарии:

1. Можете ли вы опубликовать проект common pom.xml ?

2. Евгений Ковачи, я добавил общий pom

3. Вы видели мой ответ?

4. Что произойдет, если вы закроете common-project в Eclipse?

5. Если вы запустите mvn clean install для общего проекта, он должен работать

Ответ №1:

Это потому, что общий проект является приложением Spring Boot (я вижу папку BOOT-INF внутри сгенерированного jar).

Из Используйте приложение Spring Boot в качестве документации по зависимостям:

Исполняемый архив не может использоваться как зависимость, поскольку исполняемый формат jar упаковывает классы приложений в BOOT-INF/classes. Это означает, что они не могут быть найдены, когда исполняемый файл jar используется в качестве зависимости.

Для создания двух артефактов, одного, который может использоваться как зависимость, и другого, который является исполняемым, должен быть указан классификатор. Этот классификатор применяется к имени исполняемого архива, оставляя архив по умолчанию для использования в качестве зависимости.

 <build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <classifier>exec</classifier>
            </configuration>
        </plugin>
    </plugins>
</build>
  

Вот пример:

введите описание изображения здесь

Первый jar создается с поддержкой зависимостей, второй — исполняемый файл Spring Boot.

Комментарии:

1. Евгений Ковачи, я добавил вышеупомянутый плагин (классификатор) в zuul, и я все еще получаю ту же ошибку. Фактически, никаких изменений вообще при компиляции mvn clean

2. @JimC Вы должны запустить: mvn clean install , чтобы он был в локальном репозитории maven

3. Евгений Ковачи, та же ошибка. ОШИБКА] Не удалось выполнить цель org.apache.maven.plugins:maven-compiler-plugin:3.8.0: компиляция (по умолчанию-compile) в проекте zuul: Сбой компиляции: Сбой компиляции: [ОШИБКА] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java :[14,32] пакет com.test.common.security не существует [ОШИБКА] /C:/_d/WSs/soteste/zuul/src/main/java/com/test/zuul/security/SecurityTokenConfig.java :[21,17] не удается найти символ [ОШИБКА] символ: класс JwtConfig [ОШИБКА] расположение: класс com.test.zuul.security. SecurityTokenConfig

4. @JimC Вы запускали: mvn clean install в общем проекте? В целевом каталоге вы должны увидеть 2 jar, один с exec внутри имени

5. @JimC Вы должны добавлять его только в общий проект

Ответ №2:

То, что Eclipse может разрешать проекты Eclipse из текущей открытой рабочей области как зависимости Maven в другие проекты, является особенностью Eclipse.

Если вы запускаете Maven из командной строки или из Eclipse, вы покидаете сферу Eclipse и используете обычный Maven. Обычный Maven (даже встроенный в Eclipse Maven) не знает о проектах Eclipse, он знает только артефакты, доступные в вашем локальном и настроенных удаленных репозиториях.

Поэтому правильный подход в вашем случае — сначала выполнить mvn install в вашем общем проекте. Это устанавливает common в ваш локальный репозиторий и делает его доступным для Maven.

После этого вы можете выполнить mvn clean install в своем проекте zuul.

Комментарии:

1. Роберт, правильный подход, о котором вы упомянули, — это именно то, что я делаю с помощью PowerShell