Lombok项目是一个Java库,它会自动插入编辑器和构建工具中,Lombok提供了一组有用的注释,用来消除Java类中的大量样板代码。仅五个字符(@Data)就可以替换数百行代码从而产生干净,简洁且易于维护的Java类。
一、常用注解
@Setter :注解在类或字段,注解在类时为所有字段生成setter方法,注解在字段上时只为该字段生成setter方法。
@Getter :使用方法同上,区别在于生成的是getter方法。
@ToString :注解在类,添加toString方法。
@EqualsAndHashCode: 注解在类,生成hashCode和equals方法。
@NoArgsConstructor: 注解在类,生成无参的构造方法。
@RequiredArgsConstructor: 注解在类,为类中需要特殊处理的字段生成构造方法,比如final和被@NonNull注解的字段。
@AllArgsConstructor: 注解在类,生成包含类中所有字段的构造方法。
@Data: 注解在类,生成setter/getter、equals、canEqual、hashCode、toString方法,如为final属性,则不会为该属性生成setter方法。
@Slf4j: 注解在类,生成log变量,严格意义来说是常量。
二、Lombok环境搭建
2.1、在IDEA中安装插件
File→Setting→Plugins
2.2、pom.xml中导入Lombok依赖
<!--导入Lombok依赖-->
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
<!--这里是设置作用域-->
<!--注释作用域,表明我想让它为全局使用-->
<!--<scope>provided</scope>-->
</dependency
三、测试项目
3.1、创建实体类Car,并且使用Lombok注解构建模板代码
package com.example.demo.entity.user;
import lombok.Date;@Data
//@Getter //自动构建Getter方法
//@Setter //自动构建Setter方法
//@NoArgsConstructor //自动构建无参构造方法
//@AllArgsConstructor //自动构建有参构造方法
//@ToString //自动构建toString方法
public class Car {private String brank; private double lond; private String no;
}
3.2、创建Controller测试创建实体的对象
package com.example.demo.controller; import com.example.demo.entity.user.Car; import lombok.extern.slf4j.Slf4j; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RequestMapping("/test") @RestController @Slf4j public class TestController { @GetMapping("/t1") public Car t1() { Car c = new Car(); c.setBrank("ss"); c.setLond(4); c.setNo("a6"); log.info(c.toString());//ddss log.debug("哈哈DeBUG");//以DeBUG级别输出日之类,用于程序员输出调试信息 log.info("哈哈info");//默认访问级别 log.warn("哈哈warn");//以warn级别输出日之类,用于程序员输出调警告信息 log.error("哈哈error");//以error级别输出日之类,用于程序员输出调警告信息 return c; } }
3.3、测试输出
网页访问controller输出对象
http://localhost:8080/test/t1
控制台通过Log4J输出日志
2022-06-28 16:55:09.686 INFO 4820 --- [nio-8080-exec-3] c.e.demo.controller.TestController : Car(brank=ss, lond=4.0, no=a6)
2022-06-28 16:55:09.686 INFO 4820 --- [nio-8080-exec-3] c.e.demo.controller.TestController : 哈哈info
2022-06-28 16:55:09.687 WARN 4820 --- [nio-8080-exec-3] c.e.demo.controller.TestController : 哈哈warn
2022-06-28 16:55:09.687 ERROR 4820 --- [nio-8080-exec-3] c.e.demo.controller.TestController : 哈哈error
3.4、 application.yml
添加:
#ERROR、WARN、、DEBUG logging: level: root: INFO