Spring Boot создает исключение ClassNotFoundException с зависимостью maven для другого проекта

У меня есть проект Spring Boot с простым EnvironmentPostProcessor реализация:

package com.example.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.env.EnvironmentPostProcessor;
import org.springframework.core.env.ConfigurableEnvironment;

public class DevProfilerResolverEnvironmentPostProcessor implements EnvironmentPostProcessor {

        @Override
        public void postProcessEnvironment(ConfigurableEnvironment configurableEnvironment, SpringApplication springApplication) {
            if (configurableEnvironment.getActiveProfiles().length == 0) {
                if (System.getenv().get("OS").contains("Windows")) {
                    configurableEnvironment.addActiveProfile("DEV");
                }
            }
        }
    }

Кроме того, я зарегистрировал этот класс sprig.factories:

org.springframework.boot.env.EnvironmentPostProcessor = com.example.demo.DevProfilerResolverEnvironmentPostProcessor

Теперь структура выглядит так:

Фрагмент из файла 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>

    <groupId>com.example</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>demo</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.4.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

Я казнил с Maven:

установить MVN

Теперь я хочу использовать это EnvironmentPostProcessor реализация на другом весеннем загрузочном проекте. Таким образом я добавил его в раздел зависимостей для нового проекта:

    <dependency>
        <groupId>com.example</groupId>
        <artifactId>demo</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </dependency>
</dependencies>

И я написал простое использование сервиса:

@Service
@Profile("DEV")
public class DeveloperService {

    @Scheduled(cron = "1/1 * * * * ?")
    public void doWork() {
        System.out.println("Developers.... ");
    }
}

and enabled scheduling for main class:

@SpringBootApplication
@EnableScheduling
public class LvivBootApplication {

    public static void main(String[] args) {
        SpringApplication.run(LvivBootApplication.class, args);
    }
}

Тем не менее, я получил следующее исключение после основного выполнения:

14:56:09.822 [main] ERROR org.springframework.boot.SpringApplication - Application startup failed
java.lang.IllegalArgumentException: Unable to instantiate factory class: org.springframework.boot.env.EnvironmentPostProcessor
Caused by: java.lang.ClassNotFoundException: com.example.demo.DevProfilerResolverEnvironmentPostProcessor
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)

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

Я запускаю его именно в среде Windows.

Идея заключается в том, когда ОС Windows добавить DEV профиль для первого проекта. Во-вторых, есть служба, которая выводит на консоль фиктивные данные, когда профиль DEV и запланировал эту печать на каждую секунду.

Я не могу найти то, что пропущено в этом примере?

РЕШЕНИЕ:

Для изготовления из первой библиотеки проекта банка pom должно быть исправлено следующим образом:

<!--<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <executable>true</executable>
            </configuration>
        </plugin>
    </plugins>
</build>--> 

Или просто удалить этот плагин из файла POM.

1 ответ

Решение

Ваша первая банка - это не библиотека. Это перепакованный загрузочный jar-файл, созданный подключаемым модулем Spring, содержащий первое загрузочное приложение Spring и все его зависимости, предназначенные для выполнения, а не для использования в качестве библиотеки.

Если вы хотите использовать это как библиотеку, вам нужно использовать непереупакованный файл JAR, содержащий только классы и ресурсы проекта.

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

Я публикую, потому что у меня была аналогичная ошибка в аналогичных обстоятельствах - я искал часы, и решение было очень простым. Я использую Eclipse для отладки - Eclipse не использует созданный jar из сборки Maven - он использует свой собственный набор путей сборки с, насколько я понял, взорванными классами и т. Д.

Мой проект Maven, тот, который создал JAR, который я включал в свой основной проект POM, никоим образом не декларировал какую-то зависимость от основного проекта, например, через общего родителя или что-то еще.

Eclipse, похоже, не понимает, что одна из зависимостей, которые я использовал в POM, была результатом другого локального проекта - каким-то образом, хотя файл (jar-with-dependencies) был в кеше Maven нормально, он не собирал его для копирования в свой собственный вышеупомянутый набор каталогов classpath.

Мне нужно было явно добавить его (мой проект библиотеки) в основной проект через Project -> Properties -> Java Build Path -> Projects - добавив его в список под названием "Необходимые проекты на пути сборки:"

Другие вопросы по тегам