新版本Spring中l(wèi)ombok失效的問題解決
Lombok簡(jiǎn)介 :
Lombok 是一個(gè) Java 庫,可以通過在代碼中添加注解來消除模板代碼,以簡(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-11
SpringBoot實(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-07
Flink流處理引擎零基礎(chǔ)速通之?dāng)?shù)據(jù)的抽取篇
今天不分享基礎(chǔ)概念知識(shí)了,來分享一個(gè)馬上工作需要的場(chǎng)景,要做數(shù)據(jù)的抽取,不用kettle,想用flink。實(shí)際就是flink的sql、table層級(jí)的api2022-05-05
eclipse啟動(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-08
springboot創(chuàng)建多module項(xiàng)目的實(shí)例
這篇文章主要介紹了springboot創(chuàng)建多module項(xiàng)目的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02

