新版本Spring中l(wèi)ombok失效的問題解決
Lombok簡(jiǎn)介 :
Lombok 是一個(gè) Java 庫(kù),可以通過在代碼中添加注解來消除模板代碼,以簡(jiǎn)化 Java 代碼的編寫過程; Lombok 支持自動(dòng)生成 getter、setter、toString等方法,減少了重復(fù)性的開發(fā)工作。
.idea中安裝lombok插件:
- 引入 Lombok 的依賴是讓編譯器能夠找到 Lombok 提供的注解并對(duì)其進(jìn)行處理,但是這不足 以讓 IDE 可以正常地識(shí)別和支持 Lombok 的注解。
- 為了在 IDE 中正常地使用 Lombok,需要安裝 IDE 插件來支持 Lombok 的注解。插件會(huì)將 Lombok 的注解轉(zhuǎn)換為相應(yīng)的代碼,以便能夠在 IDE 中正確地顯示代碼提示等功能。
- 所以,為了使 Lombok 的注解在 IDE 中正常運(yùn)行,需要同時(shí)引入 Lombok 的依賴并安裝對(duì)應(yīng) 的 IDE 插件。
問題解決
原因是今天在創(chuàng)建新項(xiàng)目的時(shí)候,引入了Lombok,結(jié)果在使用的時(shí)候,所有的注解都失效了,報(bào)出類似于找不到符號(hào)的錯(cuò)誤
解決方法是: 原因是Spring官方進(jìn)行了升級(jí), 在創(chuàng)建項(xiàng)目時(shí)添加lombok依賴的話, 會(huì)自動(dòng)引入一個(gè)插件(之前沒有, 新增的), 把這個(gè)插件刪了就可以了
測(cè)試案例:
pom.xml
<properties> <java.version>1.8</java.version> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.build.outputEncoding>UTF-8</project.build.outputEncoding> <spring-boot.version>2.6.13</spring-boot.version> </properties> <dependencies> <!--<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency>--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>${spring-boot.version}</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <version>${spring-boot.version}</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <version>${spring-boot.version}</version> <scope>test</scope> </dependency> <!--添加Knife4j依賴--> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>knife4j-openapi2-spring-boot-starter</artifactId> <version>4.3.0</version> </dependency> <!--引入Lombok依賴--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.32</version> </dependency> <!-- Spring Boot支持Spring Validation的依賴項(xiàng),用于檢查參數(shù)的基本有效性 --> <!--有時(shí)候idea要求必須寫version否則報(bào)錯(cuò)--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> <version>3.2.5</version> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.1</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>${spring-boot.version}</version> <configuration> <mainClass>com.zyq.lombok.MainClassTest</mainClass> <skip>true</skip> </configuration> <executions> <execution> <id>repackage</id> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
application.properties:
server.port=8080 logging.level.root=WARN logging.level.com.zyq.lombok=WARN #logging.level.com.zyq.lombok=DEBUG
主啟動(dòng)類:
package com.zyq.lombok; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class MainClass { public static void main(String[] args) { SpringApplication.run(MainClass.class); } }
實(shí)體類:
package com.zyq.lombok.entity; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import org.springframework.stereotype.Component; @Component @Data @NoArgsConstructor @AllArgsConstructor public class User { private Long id; private String userName; private String password; } // @Data 是一個(gè)組合的注解,它等價(jià)于同時(shí)使用了 @Getter 、 @Setter 、 @ToString 注解 // (如果要給類生成構(gòu)造方法需要另外標(biāo)注@AllArgsConstructor 和 @NoArgsConstructor )。
測(cè)試類:
package com.zyq.lombok; import com.zyq.lombok.entity.User; import lombok.extern.slf4j.Slf4j; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; @Slf4j @SpringBootTest public class MainClassTest{ @Autowired User u; @Test void contextLoads() { log.info("before"); u.setId( 1001L ); u.setUserName("zs"); u.setPassword("123"); System.out.println(u); System.out.println( new User(10L, "ls", "123") ); log.info("after"); } } //當(dāng)src/main/java文件夾下有與src/test/java文件夾下相同名字的類時(shí),執(zhí)行該類的測(cè)試方法就會(huì)報(bào)錯(cuò) // (!!! JUnit version 3.8 or later expected: java.lang.ClassNotFoundException: junit.framework.ComparisonFailure) //日志級(jí)別: trace < debug < info < warn < error
到此這篇關(guān)于新版本Spring中l(wèi)ombok失效的問題解決的文章就介紹到這了,更多相關(guān)Spring lombok失效內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java 定時(shí)器Timer和TimerTask的使用詳解(執(zhí)行和暫停)
這篇文章主要介紹了java 定時(shí)器Timer和TimerTask的使用詳解(執(zhí)行和暫停),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11SpringBoot實(shí)現(xiàn)Read Through模式的操作過程
Read Through模式通常是指一種緩存策略,其中當(dāng)應(yīng)用程序嘗試讀取數(shù)據(jù)時(shí),緩存系統(tǒng)首先被檢查以查看數(shù)據(jù)是否已經(jīng)存在于緩存中,這篇文章主要介紹了SpringBoot實(shí)現(xiàn)Read Through模式,需要的朋友可以參考下2024-07-07Flink流處理引擎零基礎(chǔ)速通之?dāng)?shù)據(jù)的抽取篇
今天不分享基礎(chǔ)概念知識(shí)了,來分享一個(gè)馬上工作需要的場(chǎng)景,要做數(shù)據(jù)的抽取,不用kettle,想用flink。實(shí)際就是flink的sql、table層級(jí)的api2022-05-05eclipse啟動(dòng)一個(gè)Springboot項(xiàng)目
本文主要介紹了eclipse啟動(dòng)一個(gè)Springboot項(xiàng)目,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08springboot創(chuàng)建多module項(xiàng)目的實(shí)例
這篇文章主要介紹了springboot創(chuàng)建多module項(xiàng)目的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02