1.@Slf4j的作用?
很简单的就是为了能够少写两行代码,不用每次都在类的最前边写上:
private static final Logger logger = LoggerFactory.getLogger(this.XXX.class);
我们只需要在类前面添加注解@Slf4j,即可使用log日志的功能了
2.如何将@Slf4j引入到项目中?
(1)首先,确保idea中有Lombok插件(IntelliJ IDEA 2020.3及以上版本已经内置Lombok plugin了,所以不需要安装插件,只需要在项目添加Lombok依赖就能用了)
解释:为什么需要lombok:该插件中有@Slf4j注解,会将@Slf4j注解编译成:
private static final org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(this.XXX.class);
(2)在pom.xml中导入所需依赖
<!--slf4j的依赖-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.25</version>
</dependency>
<!--lombok的依赖-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.22</version>
</dependency>
3.@Slf4j怎么用
(1)在类上添加@Slf4j注解
@Service
@Slf4j //日志
public class OrderServiceImpl implements OrderService {
@Override
public Order createOrder(Long productId,Long userId) {
log.info("接收到{}号商品的下单请求,接下来调用商品微服务查询此商品信息", productId);
...
}
(2)使用十分方便,和以前的logger一样用,有info,debug,error等等,如
@Override
public Order createOrder(Long productId,Long userId) {
log.info("接收到{}号商品的下单请求,接下来调用商品微服务查询此商品信息", productId);
...
}