SpringBoot使用@Slf4j注解实现日志输出

@Slf4j 是 Lombok 库中的一个注解,它极大地简化了日志记录的代码。通过使用这个注解,Lombok 会自动在你的类中注入一个静态的日志对象。通过在类上添加 @Slf4j 注解后,可以直接在方法中使用 log.info() 等方法进行日志打印。

1、安装相关依赖

(1)添加 Maven 依赖

添加 Lombok 依赖:首先,确保项目中已经添加了 Lombok 的依赖。如果使用的是 Maven,可以在 pom.xml 文件中添加如下依赖:

XML 复制代码
<!-- Lombok 的依赖 -->
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.34</version>
    <scope>provided</scope>
</dependency>

<!-- slf4j 的依赖,可以使用 @Slf4j注解  -->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.25</version>
</dependency>

(2)安装 IDEA 插件

打开 IDEA,单击 IDEA 菜单栏"File → settings" 选项,在弹出的对话框中选择"Plugins"(插件)选项,在弹出的插件窗口的搜索栏中输入:Lombok,在搜索结果中找到 Lombok,单击"install"按钮完成安装。在安装完成后,在使用 Lombok 前需要重启 IDEA。

2、@Slf4j 注解的使用

java 复制代码
package com.pjb.pm.service.impl;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.pjb.pm.entity.UserInfo;
import com.pjb.pm.mapper.UserMapper;
import com.pjb.pm.service.IUserService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;

/**
 * 用户信息服务类
 * @author pan_junbiao
 **/
@Slf4j  //第一步:添加 @Slf4j 注解
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, UserInfo> implements IUserService
{
    /**
     * 查询用户信息
     */
    @Override
    public UserInfo getUserInfo(Long userId)
    {
        // 第二步:使用 Logger 日志
        log.trace("Trace Level");
        log.debug("Debug Level");
        log.info("Info Level");
        log.warn("Warn Level");
        log.error("Error Level");

        // Logger 日志中使用 {} 占位符
        log.info("[开始执行]查询用户ID为:{},的用户信息", userId);
        UserInfo userInfo = this.getById(userId);
        log.info("[完成执行]用户信息为:{}", userInfo);
        return userInfo;
    }

}
相关推荐
Voyager_423 分钟前
StringRedisTemplate 和 RedisTemplate 的区别是什么?
java·spring boot
杏花春雨江南24 分钟前
JavaWeb企业级项目实战:从SSH到SSM演进 + MQ/Redis/ES高可用架构落地全复盘(实战干货+避坑指南)
java·jvm·spring
lang2015092825 分钟前
Jackson 1.x到2.x的演进与Spring集成
数据库·sql·spring
UR的出不克29 分钟前
使用 Python 爬取 Bilibili 弹幕数据并导出 Excel
java·python·excel
短剑重铸之日1 小时前
《7天学会Redis》特别篇: Redis分布式锁
java·redis·分布式·后端·缓存·redission·看门狗机制
独自破碎E1 小时前
说说Java中的反射机制
java·开发语言
一直都在5721 小时前
SpringBoot3 框架快速搭建与项目工程详解
java·开发语言
子云之风1 小时前
LSPosed 项目编译问题解决方案
java·开发语言·python·学习·android studio
小北方城市网1 小时前
SpringBoot 全局异常处理与接口规范实战:打造健壮可维护接口
java·spring boot·redis·后端·python·spring·缓存
独自破碎E1 小时前
什么是Spring IOC
java·spring·rpc