切面日志记录代码
@Aspect @Order(5) @Component @Slf4j public class ControllerLogAspect { private final ThreadLocal<Long> STARTTIME_THREADLOCAL = new NamedThreadLocal<Long>("ThreadLocalStartTime"); @Pointcut("execution(public * com.xxx.controller..*.*(..))") public void controllerLog() { } @Before("controllerLog()") public void doBefore(JoinPoint joinPoint) throws Throwable { // 开始时间(该数据只有当前请求的线程可见) STARTTIME_THREADLOCAL.set(System.currentTimeMillis()); // 接收到请求,记录请求内容 ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = attributes.getRequest(); // 只记录post方法 if("POST".equals(request.getMethod())){ // 记录下请求内容 log.info("********************************************"); log.info("请求URL : " + request.getRequestURL()); log.info("客户端ip ["+ request.getRemoteAddr() +"]"); log.info("请求映射 : 【" + joinPoint.getSignature().getDeclaringTypeName() + "】类的【" + joinPoint.getSignature().getName() + "】方法"); // 获取参数, 只取自定义的参数, 自带的HttpServletRequest, HttpServletResponse不管 if (joinPoint.getArgs().length > 0) { for (Object o : joinPoint.getArgs()) { if (Objects.isNull(o) || o instanceof MultipartFile || o instanceof MultipartFile[] || o instanceof HttpServletRequest || o instanceof HttpServletResponse) { continue; } log.info("请求参数 : " + JSONObject.toJSONString(o)); } } } // 只记录post方法 if("GET".equals(request.getMethod())){ // 记录下请求内容 log.info("请求URL : " + request.getRequestURL()); log.info("请求IP : " + request.getRemoteAddr()); log.info("请求映射 : 【" + joinPoint.getSignature().getDeclaringTypeName() + "】类的【" + joinPoint.getSignature().getName() + "】方法"); // 获取参数, 只取自定义的参数, 自带的HttpServletRequest, HttpServletResponse不管 if (joinPoint.getArgs().length > 0) { for (Object o : joinPoint.getArgs()) { if (Objects.isNull(o) || o instanceof MultipartFile || o instanceof MultipartFile[] || o instanceof HttpServletRequest || o instanceof HttpServletResponse) { continue; } log.info("请求参数 : " + JSONObject.toJSONString(o)); } } } } @AfterReturning(returning = "ret", pointcut = "controllerLog()") public void doAfterReturning(Object ret) throws Throwable { final Long startTime = STARTTIME_THREADLOCAL.get(); final Long endTime = System.currentTimeMillis(); String message = "开始时间: {}; 结束时间: {}; 耗时: {}s; 返回: {}; "; // 处理完请求,返回内容 log.info(message, DateUtil.format(startTime, "HH:mm:ss.SSS"), DateUtil.format(endTime, "HH:mm:ss.SSS"), String.valueOf((endTime - startTime) / 1000.00), JSONObject.toJSONString(ret)); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏