SpringBoot配置集成log4j统一处理请求日志(AOP)


springboot中集成log4j需要3步就可以配置完成

1. 添加log4j依赖

<!-- pom.xml添加log4j依赖,最新版本可以去maven网站下载 -->
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-log4j</artifactId>
  <version>1.3.8.RELEASE</version>
</dependency>

2. log4j配置

log4j日志的配置可以用log4j.xml,log4j.properties这2种形式配置。log4j的配置文件一般放在resources文件夹下。
 

log4j.rootLogger=INFO,Console,File
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.Target=System.out
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c - %L]%m%n
log4j.appender.File=org.apache.log4j.RollingFileAppender
log4j.appender.File.File=D:/logs/info/info.log
log4j.appender.File.MaxFileSize=10MB
log4j.appender.File.Threshold=ALL
log4j.appender.File.layout=org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern=[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c - %L]%m%n

3. 配置完成,Controller中使用log4j

@RestController
@RequestMapping("log4j")
public class Log4jController {
    Logger logger=Logger.getLogger(Log4jController.class);

    @RequestMapping("logtest")
    @ResponseBody
    public String logtest(){

        logger.fatal("致命错误");
        logger.error("严重警告");
        logger.warn("警告");
        logger.info("普通信息");
        logger.debug("调试信息");

        return "testLog4j";
    }
}

4.验证

在浏览器输入:http://127.0.0.1:8080/log4j/logtest

 打印log下图所示:

SpringBoot+log4j统一处理请求日志(AOP)


项目当中经常需要对请求日志进行统一处理,以便能够及时的掌握项目功能情况,下面简单介绍springboot利用log4j如何用AOP对所有请求统一记录。

1. springboot集成log4j

具体详见springboot配置集成log4j(上面的步骤)

2. 导入AOP依赖

<!-- AOP -->
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-aop</artifactId>
</dependency>

3. WebLogAspect切面类

package com.myspringboot.controller;

import java.util.Enumeration;
import javax.servlet.http.HttpServletRequest;
import org.apache.log4j.Logger;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

@Aspect
@Component  //配置Bean

public class WebLogAspect {
    private Logger logger = Logger.getLogger(getClass());
    
    private long startTime=0;

    @Pointcut("execution(public * com.myspringboot.controller..*.*(..))")
    //com.myspringboot.controller  为Controller所在的包名

    public void webLog() {

    }

    @Before("webLog()")
    public void doBefore(JoinPoint joinPoint) throws Throwable {
        startTime = System.currentTimeMillis();
        // 接收到请求,记录请求内容
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        // 记录下请求内容
        logger.info("---------------request----------------");
        logger.info("URL : " + request.getRequestURL().toString());
        logger.info("HTTP_METHOD : " + request.getMethod());
        logger.info("IP : " + request.getRemoteAddr());
        Enumeration enu = request.getParameterNames();
        while (enu.hasMoreElements()) {
            String name = (String) enu.nextElement();
            logger.info("name:" + name + " - value:" + request.getParameter(name));
        }
    }


    @AfterReturning(returning = "ret", pointcut = "webLog()")
    public void doAfterReturning(Object ret) throws Throwable {
        logger.info("---------------response----------------");
        // 处理完请求,返回内容
        logger.info("RESPONSE : " + ret);
        logger.info("花费时间 : " + (System.currentTimeMillis() - startTime) + "毫秒");
    }
    
    // 通过@Pointcut定义切入点,此处是com.test.controller包下的所有Controller(对controller层所有请求处理做切入点),
    // 然后通过@Before实现对请求内容的日志记录,最后通过@AfterReturning记录请求返回的对象。
    // 这样所有功能的请求参数,返回数据,以及运行时间等都可以统一记录,不需要在每个方法去单独处理。
}
 

 4.验证

在浏览器输入:http://127.0.0.1:8080/log4j/logtest

相关参考文档

springboot+log4j统一处理请求日志(AOP)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值