cn.mklaus.framework.config.monitor.WebLogAspect Maven / Gradle / Ivy
package cn.mklaus.framework.config.monitor;
import com.alibaba.fastjson.JSON;
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.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
/**
* @author Mklaus
* Created on 2018-01-29 下午12:46
*/
@Aspect
@Order(1)
@Component
@ConditionalOnProperty(prefix = "cn.mklaus.config", value = "logRequest", matchIfMissing = true, havingValue = "true")
public class WebLogAspect {
private static Logger log = LoggerFactory.getLogger(WebLogAspect.class);
@Pointcut("execution(public * *..web.*Controller.*(..))")
public void webLog(){}
@Before("webLog()")
public void doBefore(JoinPoint joinPoint) {
// 接收到请求,记录请求内容
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
// 记录下请求内容
log.info("================== check request information start.. ========================");
log.info("URL : {} {}", request.getRequestURL().toString(), request.getMethod());
log.info("METHOD : {}.{}", joinPoint.getSignature().getDeclaringTypeName(),joinPoint.getSignature().getName());
log.info("ARGS : {}", JSON.toJSONString(request.getParameterMap()));
log.info("================== check request information end ... ========================");
}
@AfterReturning(returning = "ret", pointcut = "webLog()")
public void doAfterReturning(Object ret) {
log.info("RESPONSE : " + ret);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy