mapstruct / mapstruct-spring-extensions

Helpful additions to MapStruct when using the Spring Framework.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

maven Compilation failed [JDK20 MAVEN3.9.2 ] javax.annotation.processing.Processor: Provider org.mapstruct.extensions.spring.converter.ConverterMapperProcessor could not be instantiated

iqolome opened this issue · comments

environment

Java and Maven information

C:Usersqolom>java -version
java version "20.0.1" 2023-04-18
Java(TM) SE Runtime Environment (build 20.0.1+9-29)
Java HotSpot(TM) 64-Bit Server VM (build 20.0.1+9-29, mixed mode, sharing)

C:Usersqolom>mvn -v
Apache Maven 3.9.2 (c9616018c7a021c1c39be70fb2843d6f5f9b8a1c)
Maven home: D:Serverapache-maven-3.9.2
Java version: 20.0.1, vendor: Oracle Corporation, runtime: C:Program FilesJavajdk-20
Default locale: zh_CN, platform encoding: UTF-8
OS name: "windows 11", version: "10.0", arch: "amd64", family: "windows"

pom information

<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>
        <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-parent -->
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.1.0</version>
        <relativePath/>
        <!-- lookup parent from repository -->
    </parent>




    <properties>
        <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
        <lombok.version>1.18.28</lombok.version>

        <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok-mapstruct-binding -->
        <lombok-mapstruct-binding.version>0.2.0</lombok-mapstruct-binding.version>

        <!-- https://mvnrepository.com/artifact/org.mapstruct/mapstruct -->
        <mapstruct.version>1.5.5.Final</mapstruct.version>

        <!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-annotations -->
        <mapstruct-spring-annotations.version>1.0.1</mapstruct-spring-annotations.version>

        <!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-extensions -->
        <mapstruct-spring-extensions.version>1.0.1</mapstruct-spring-extensions.version>


          <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-dependencies -->
        <spring-cloud-dependencies.version>2022.0.3</spring-cloud-dependencies.version>

    </properties>

<dependencies>
    <dependency>
        <groupId>org.mapstruct</groupId>
        <artifactId>mapstruct</artifactId>
        <version>${mapstruct.version}</version>
    </dependency>
    <dependency>
        <groupId>org.mapstruct.extensions.spring</groupId>
        <artifactId>mapstruct-spring-extensions</artifactId>
        <version>${mapstruct-spring-extensions.version}</version>
    </dependency>
    <dependency>
        <groupId>org.mapstruct</groupId>
        <artifactId>mapstruct-processor</artifactId>
         <version>${mapstruct.version}</version>
    </dependency>
    <dependency>
        <groupId>org.mapstruct.extensions.spring</groupId>
        <artifactId>mapstruct-spring-annotations</artifactId>
        <version>${mapstruct-spring-annotations.version}</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
         <version>${lombok.version}</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok-mapstruct-binding</artifactId>
        <version>${lombok-mapstruct-binding.version}</version>
    </dependency>


    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </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-configuration-processor</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-autoconfigure</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-consul-all</artifactId>
    </dependency>
    <dependency>
        <groupId>net.logstash.logback</groupId>
        <artifactId>logstash-logback-encoder</artifactId>
    </dependency>


    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
    </dependency>


    <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
    </dependency>
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-core</artifactId>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-annotations</artifactId>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.datatype</groupId>
        <artifactId>jackson-datatype-jsr310</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-validation</artifactId>
    </dependency>
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-lang3</artifactId>
    </dependency>
    <dependency>
        <groupId>commons-beanutils</groupId>
        <artifactId>commons-beanutils</artifactId>
    </dependency>
    <dependency>
        <groupId>cn.hutool</groupId>
        <artifactId>hutool-all</artifactId>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.springdoc/springdoc-openapi-common -->
    <dependency>
        <groupId>org.springdoc</groupId>
        <artifactId>springdoc-openapi-common</artifactId>
    </dependency>

</dependencies>




</project>






Related logs

"C:\Program Files\Java\jdk-20\bin\java.exe" -Dvisualvm.id=8147785106100 -Dmaven.multiModuleProjectDirectory=D:\workspace\cloud-workspace\cloud-common -Djansi.passthrough=true -Xms512m -Xmx1024m -Dfile.encoding=UTF-8 -Dmaven.home=D:\Server\apache-maven-3.9.2 -Dclassworlds.conf=D:\Server\apache-maven-3.9.2\bin\m2.conf "-Dmaven.ext.class.path=D:\Software\IntelliJ IDEA 2023.1.2\plugins\maven\lib\maven-event-listener.jar" "-javaagent:D:\Software\IntelliJ IDEA 2023.1.2\lib\idea_rt.jar=58531:D:\Software\IntelliJ IDEA 2023.1.2\bin" -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath D:\Server\apache-maven-3.9.2\boot\plexus-classworlds-2.7.0.jar;D:\Server\apache-maven-3.9.2\boot\plexus-classworlds.license org.codehaus.classworlds.Launcher -Didea.version=2023.1.2 --update-snapshots -s D:\Server\apache-maven-3.9.2\conf\settings.xml clean package install
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Build Order:
[INFO] 
[INFO] cloud-common                                                       [pom]
[INFO] cloud-common-client                                                [jar]
[INFO] cloud-common-server                                                [jar]
[INFO] 
[INFO] -------------------< com.qolome.cloud:cloud-common >--------------------
[INFO] Building cloud-common 2.1.3-jre20                                  [1/3]
[INFO]   from pom.xml
[INFO] --------------------------------[ pom ]---------------------------------
[INFO] 
[INFO] --- clean:3.2.0:clean (default-clean) @ cloud-common ---
[INFO] 
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common >>>
[INFO] 
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common <<<
[INFO] 
[INFO] 
[INFO] --- source:3.2.1:jar (default) @ cloud-common ---
[INFO] 
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common ---
[INFO] Not executing Javadoc as the project is not a Java classpath-capable package
[INFO] 
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common >>>
[INFO] 
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common <<<
[INFO] 
[INFO] 
[INFO] --- source:3.2.1:jar (default) @ cloud-common ---
[INFO] 
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common ---
[INFO] Not executing Javadoc as the project is not a Java classpath-capable package
[INFO] 
[INFO] --- install:3.1.1:install (default-install) @ cloud-common ---
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\pom.xml to D:\Server\Repository\com\qolome\cloud\cloud-common\2.1.3-jre20\cloud-common-2.1.3-jre20.pom
[INFO] 
[INFO] ----------------< com.qolome.cloud:cloud-common-client >----------------
[INFO] Building cloud-common-client 2.1.3-jre20                           [2/3]
[INFO]   from cloud-common-client\pom.xml
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- clean:3.2.0:clean (default-clean) @ cloud-common-client ---
[INFO] Deleting D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target
[INFO] 
[INFO] --- resources:3.3.1:resources (default-resources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO] 
[INFO] --- compiler:3.11.0:compile (default-compile) @ cloud-common-client ---
[INFO] Changes detected - recompiling the module! :source
[INFO] Compiling 25 source files with javac [debug release 20] to target\classes
[INFO] 
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common-client >>>
[INFO] 
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common-client <<<
[INFO] 
[INFO] 
[INFO] --- source:3.2.1:jar (default) @ cloud-common-client ---
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-sources.jar
[INFO] 
[INFO] --- resources:3.3.1:testResources (default-testResources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\test\resources
[INFO] 
[INFO] --- compiler:3.11.0:testCompile (default-testCompile) @ cloud-common-client ---
[INFO] No sources to compile
[INFO] 
[INFO] --- surefire:3.0.0:test (default-test) @ cloud-common-client ---
[INFO] No tests to run.
[INFO] 
[INFO] --- jar:3.3.0:jar (default-jar) @ cloud-common-client ---
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20.jar
[INFO] 
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common-client ---
[INFO] No previous run data found, generating javadoc.
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-javadoc.jar
[INFO] 
[INFO] --- resources:3.3.1:resources (default-resources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO] 
[INFO] --- compiler:3.11.0:compile (default-compile) @ cloud-common-client ---
[INFO] Nothing to compile - all classes are up to date
[INFO] 
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common-client >>>
[INFO] 
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common-client <<<
[INFO] 
[INFO] 
[INFO] --- source:3.2.1:jar (default) @ cloud-common-client ---
[WARNING] artifact com.qolome.cloud:cloud-common-client:java-source:sources:2.1.3-jre20 already attached, replace previous instance
[INFO] 
[INFO] --- resources:3.3.1:testResources (default-testResources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\test\resources
[INFO] 
[INFO] --- compiler:3.11.0:testCompile (default-testCompile) @ cloud-common-client ---
[INFO] No sources to compile
[INFO] 
[INFO] --- surefire:3.0.0:test (default-test) @ cloud-common-client ---
[INFO] No tests to run.
[INFO] Skipping execution of surefire because it has already been run for this configuration
[INFO] 
[INFO] --- jar:3.3.0:jar (default-jar) @ cloud-common-client ---
[INFO] 
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common-client ---
[INFO] Configuration changed, re-generating javadoc.
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-javadoc.jar
[WARNING] artifact com.qolome.cloud:cloud-common-client:javadoc:javadoc:2.1.3-jre20 already attached, replace previous instance
[INFO] 
[INFO] --- install:3.1.1:install (default-install) @ cloud-common-client ---
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\pom.xml to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20.pom
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20.jar to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20.jar
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-sources.jar to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20-sources.jar
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-javadoc.jar to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20-javadoc.jar
[INFO] 
[INFO] ----------------< com.qolome.cloud:cloud-common-server >----------------
[INFO] Building cloud-common-server 2.1.3-jre20                           [3/3]
[INFO]   from cloud-common-server\pom.xml
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- clean:3.2.0:clean (default-clean) @ cloud-common-server ---
[INFO] Deleting D:\workspace\cloud-workspace\cloud-common\cloud-common-server\target
[INFO] 
[INFO] --- resources:3.3.1:resources (default-resources) @ cloud-common-server ---
[INFO] Copying 0 resource from src\main\resources to target\classes
[INFO] Copying 1 resource from src\main\resources to target\classes
[INFO] 
[INFO] --- compiler:3.11.0:compile (default-compile) @ cloud-common-server ---
[INFO] Changes detected - recompiling the module! :dependency
[INFO] Compiling 9 source files with javac [debug release 20] to target\classes
[INFO] -------------------------------------------------------------
[ERROR] COMPILATION ERROR : 
[INFO] -------------------------------------------------------------
[ERROR] 服务配置文件不正确, 或构造处理程序对象javax.annotation.processing.Processor: Provider org.mapstruct.extensions.spring.converter.ConverterMapperProcessor could not be instantiated时抛出异常错误
[INFO] 1 error
[INFO] -------------------------------------------------------------
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary for cloud-common 2.1.3-jre20:
[INFO] 
[INFO] cloud-common ....................................... SUCCESS [  0.663 s]
[INFO] cloud-common-client ................................ SUCCESS [  4.449 s]
[INFO] cloud-common-server ................................ FAILURE [  0.586 s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  5.914 s
[INFO] Finished at: 2023-06-17T16:27:29+08:00
[INFO] ------------------------------------------------------------------------
[WARNING] 
[WARNING] Plugin validation issues were detected in 2 plugin(s)
[WARNING] 
[WARNING]  * org.apache.maven.plugins:maven-source-plugin:3.2.1
[WARNING]  * org.apache.maven.plugins:maven-javadoc-plugin:3.5.0
[WARNING] 
[WARNING] For more or less details, use 'maven.plugin.validation' property with one of the values (case insensitive): [BRIEF, DEFAULT, VERBOSE]
[WARNING] 
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.11.0:compile (default-compile) on project cloud-common-server: Compilation failure
[ERROR] 服务配置文件不正确, 或构造处理程序对象javax.annotation.processing.Processor: Provider org.mapstruct.extensions.spring.converter.ConverterMapperProcessor could not be instantiated时抛出异常错误
[ERROR] 
[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
[ERROR] 
[ERROR] After correcting the problems, you can resume the build with the command
[ERROR]   mvn <args> -rf :cloud-common-server

Process finished with exit code 1

@Chessray Thanks, found the problem

 <properties>
        <java.version>20</java.version>
        <maven.compiler.release>20</maven.compiler.release>
        <maven.compiler.source>20</maven.compiler.source>
        <maven.compiler.target>20</maven.compiler.target>
        <maven.compiler.encoding>UTF-8</maven.compiler.encoding>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

        <!-- mapstruct IDE Support -->
        <m2e.apt.activation>jdt_apt</m2e.apt.activation>


 <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
        <lombok.version>1.18.28</lombok.version>

        <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok-mapstruct-binding -->
        <lombok-mapstruct-binding.version>0.2.0</lombok-mapstruct-binding.version>

        <!-- https://mvnrepository.com/artifact/org.mapstruct/mapstruct -->
        <mapstruct.version>1.5.5.Final</mapstruct.version>

        <!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-annotations -->
        <mapstruct-spring-annotations.version>1.0.1</mapstruct-spring-annotations.version>

        <!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-extensions -->
        <mapstruct-spring-extensions.version>1.0.1</mapstruct-spring-extensions.version>


    </properties>


<plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <configuration>
                        <source>${maven.compiler.source}</source>
                        <target>${maven.compiler.source}</target>
                        <annotationProcessorPaths>
                            <path>
                                <groupId>org.mapstruct</groupId>
                                <artifactId>mapstruct-processor</artifactId>
                                <version>${mapstruct.version}</version>
                            </path>
                            <path>
                                <groupId>org.mapstruct.extensions.spring</groupId>
                                <artifactId>mapstruct-spring-extensions</artifactId>
                                <version>${mapstruct-spring-extensions.version}</version>
                            </path>

                            <path>
                                <groupId>org.projectlombok</groupId>
                                <artifactId>lombok</artifactId>
                                <version>${lombok.version}</version>
                            </path>
                        </annotationProcessorPaths>
                    </configuration>
                </plugin>