定义了controller下的请求日志

This commit is contained in:
Hzm
2025-09-21 19:27:50 +08:00
parent db7dbcc97e
commit eb5978eb9d

View File

@@ -0,0 +1,44 @@
package com.agileboot.common.web.aspect;
import jakarta.servlet.http.HttpServletRequest;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
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;
import java.util.Arrays;
@Aspect
@Slf4j
@Component
public class LogAspect {
@Pointcut("execution(* *..controller..*.*(..))")
public void logPointCut() {
}
@Around("logPointCut()")
public Object around(ProceedingJoinPoint point) throws Throwable {
// 获取HTTP请求对象
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.currentRequestAttributes()).getRequest();
// 获取请求URL
String url = request.getRequestURI().toString();
// 获取方法参数
Object[] args = point.getArgs();
String reqParam = Arrays.toString(args); // 直接使用 Arrays.toString()
// 输出请求日志
log.info("request start, path: {}, params: {}", url, reqParam);
Object res = point.proceed();
return res;
}
}