springboot日志输出异常_SpringBoot实战 - AOP统一打印日志

目录

前言

面向切面编程 是 Spring 里一种很不错的编程思想,简单来讲就是可以将一段功能代码在程序运行时,动态地将该段代码切入到目标方法前或后插入去执行,这种方式可以实现代码的可插拔性,之前我们在拦截器实战篇中说过的拦截器其实就是切面编程的一种实现。

本篇文章我们将带你使用 Spring 的 @Aspect 注解来实现 Controller 层方法的请求参数、响应体的日志打印功能,这在企业开发中也是很有必要的哦,可以减少我们浪费在日志打印上的一些时间,也可以统一日志的打印格式,以后在使用 ELK 这种日志搜索服务时,你也将会得到很不错的使用体验。

思路

我们使用 @Aspect 标识一个切面类,使用 @Around 注解标识在你打印日志的方法里,主要捕捉@RestController 带这个注解的类方法,也就是我们的 RestController下的方法,这样就可以在joinPoint.proceed() 程序的处理前后打印上日志信息,我们目前打印的主要信息有,请求者、请求的类.方法名字、请求的参数(参数敏感信息需要用 “**”替换)、请求者 IP、调用源、App 版本号、Api 版本号、客户端的 UserAgent 信息、响应的结果(敏感词过滤)、最后请求结束后所花费的时间。

好了,说了这么多接下来我们看下源码吧。

package cn.notemi.demo.aspect;

import java.lang.reflect.Method;

import java.util.List;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import cn.notemi.demo.model.bo.LoginUser;

import cn.notemi.demo.util.IpUtil;

import com.google.common.base.Strings;

import org.aspectj.lang.ProceedingJoinPoint;

import org.aspectj.lang.annotation.Around;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.reflect.MethodSignature;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Component;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.context.request.RequestContextHolder;

import org.springframework.web.context.request.ServletRequestAttributes;

import org.springframework.web.multipart.MultipartFile;

import com.alibaba.fastjson.JSON;

import com.alibaba.fastjson.JSONObject;

import com.google.commo

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值