spring项目整合log4j2日志框架(含log4j无法打印出日志的情况,含解决办法)

Spring整合Log4j2的整体流程

Lo

1)导入log4j-core依赖

<!--导入日志框架-->

<dependency>

<groupId>org.apache.logging.log4j</groupId>

<artifactId>log4j-core</artifactId>

<version>2.20.0</version>

</dependency>

2)创建log4j2.xml文件

在项目中resource目录下创建log4j2.xml文件

3)配置log4j.xml文件

<?xml version="1.0" encoding="UTF-8"?>

<Configuration status="WARN">

<Appenders>

<!--配置控制台输出日志-->

<Console name="Console" target="SYSTEM_OUT">

<!--日志的输出格式-->

<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>

</Console>

<!--配置文件输出日志-->

<File name="File" fileName="d:/logs/app.log">

<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>

</File>

</Appenders>

<Loggers>

<!--日志级别为debug-->

<Root level="debug">

<AppenderRef ref="Console"/>

<AppenderRef ref="File"/>

</Root>

</Loggers>

</Configuration>

4)测试

注:这个需要使用spring框架创建对象才能显示出log4j日志

Logj4无法打印的日志情况

1)不是使用spring框架创建对象,使用反射创建对象

2)不是使用spring框架创建对象,使用手动创建对象的方式创建对象

以上两种都没有日志打印

3)解决办法

1.通过导入log4j-slf4j2-impl jar包

<dependency>

<groupId>org.apache.logging.log4j</groupId>

<artifactId>log4j-slf4j2-impl</artifactId>

<version>2.23.1</version>

</dependency>

2.然后在创建Logger

private static Logger logger= LoggerFactory.getLogger(当前类.class);

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.xiji.Users;

public class CreateUsersByHandTest {

private static Logger logger= LoggerFactory.getLogger(CreateUsersByHandTest.class);

@Test
public void createUsers(){
System.out.println("通过手写创建");

Users users = new Users();
/**
手动输出日志即可解决
*/
logger.info("通过log4j2打印日志"+users);
System.out.println(users);
users.userInfo();
}
}

3.测试结果
相关推荐
爱晒太阳的小老鼠4 分钟前
策略模式-枚举实现
java·策略模式
77tian11 分钟前
设计模式的原理及深入解析
java·开发语言·单例模式·设计模式·代理模式·享元模式·原型模式
fluxcode20 分钟前
Visual Studio构建三剑客:生成/重新生成/清理解决方案的正确打开方式
其他·log4j·apache·visual studio
会飞的架狗师1 小时前
【Spring Cloud Gateway】Nacos整合遇坑记:503 Service Unavailable
java·开发语言
重生之后端学习2 小时前
02-前端Web开发(JS+Vue+Ajax)
java·开发语言·前端·javascript·vue.js
字节源流8 小时前
关于maven的依赖下不下来的问题
java·maven
pjx9878 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡
prinrf('千寻)9 小时前
MyBatis-Plus 的 updateById 方法不更新 null 值属性的问题
java·开发语言·mybatis
老华带你飞9 小时前
实习记录小程序|基于SSM+Vue的实习记录小程序设计与实现(源码+数据库+文档)
java·数据库·spring boot·小程序·论文·毕设·实习记录小程序
在未来等你9 小时前
互联网大厂Java求职面试:AI与大模型应用集成及云原生挑战
java·微服务·ai·kubernetes·大模型·embedding·spring ai