新版本Spring中l(wèi)ombok失效的問題解決
Lombok簡介 :
Lombok 是一個 Java 庫,可以通過在代碼中添加注解來消除模板代碼,以簡化 Java 代碼的編寫過程; Lombok 支持自動生成 getter、setter、toString等方法,減少了重復(fù)性的開發(fā)工作。
.idea中安裝lombok插件:
- 引入 Lombok 的依賴是讓編譯器能夠找到 Lombok 提供的注解并對其進(jìn)行處理,但是這不足 以讓 IDE 可以正常地識別和支持 Lombok 的注解。
- 為了在 IDE 中正常地使用 Lombok,需要安裝 IDE 插件來支持 Lombok 的注解。插件會將 Lombok 的注解轉(zhuǎn)換為相應(yīng)的代碼,以便能夠在 IDE 中正確地顯示代碼提示等功能。
- 所以,為了使 Lombok 的注解在 IDE 中正常運行,需要同時引入 Lombok 的依賴并安裝對應(yīng) 的 IDE 插件。
問題解決
原因是今天在創(chuàng)建新項目的時候,引入了Lombok,結(jié)果在使用的時候,所有的注解都失效了,報出類似于找不到符號的錯誤

解決方法是: 原因是Spring官方進(jìn)行了升級, 在創(chuàng)建項目時添加lombok依賴的話, 會自動引入一個插件(之前沒有, 新增的), 把這個插件刪了就可以了

測試案例:
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的依賴項,用于檢查參數(shù)的基本有效性 -->
<!--有時候idea要求必須寫version否則報錯-->
<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
主啟動類:
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);
}
}
實體類:
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 是一個組合的注解,它等價于同時使用了 @Getter 、 @Setter 、 @ToString 注解
// (如果要給類生成構(gòu)造方法需要另外標(biāo)注@AllArgsConstructor 和 @NoArgsConstructor )。測試類:
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文件夾下相同名字的類時,執(zhí)行該類的測試方法就會報錯
// (!!! JUnit version 3.8 or later expected: java.lang.ClassNotFoundException: junit.framework.ComparisonFailure)
//日志級別: trace < debug < info < warn < error到此這篇關(guān)于新版本Spring中l(wèi)ombok失效的問題解決的文章就介紹到這了,更多相關(guān)Spring lombok失效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java 定時器Timer和TimerTask的使用詳解(執(zhí)行和暫停)
這篇文章主要介紹了java 定時器Timer和TimerTask的使用詳解(執(zhí)行和暫停),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11
SpringBoot實現(xiàn)Read Through模式的操作過程
Read Through模式通常是指一種緩存策略,其中當(dāng)應(yīng)用程序嘗試讀取數(shù)據(jù)時,緩存系統(tǒng)首先被檢查以查看數(shù)據(jù)是否已經(jīng)存在于緩存中,這篇文章主要介紹了SpringBoot實現(xiàn)Read Through模式,需要的朋友可以參考下2024-07-07
Flink流處理引擎零基礎(chǔ)速通之?dāng)?shù)據(jù)的抽取篇
今天不分享基礎(chǔ)概念知識了,來分享一個馬上工作需要的場景,要做數(shù)據(jù)的抽取,不用kettle,想用flink。實際就是flink的sql、table層級的api2022-05-05
springboot創(chuàng)建多module項目的實例
這篇文章主要介紹了springboot創(chuàng)建多module項目的實例代碼,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02

