版权声明:本博客为记录本人学习过程而开,内容大多从网上学习与整理所得,若侵权请告知! https://blog.csdn.net/Fly_as_tadpole/article/details/84489127
pom.xml添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
实现部分:
package com.sayhello.sayhello.Aspect;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.HttpRequest;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
@Aspect
@Component
public class HttpAspect {
private Logger logger = LoggerFactory.getLogger(HttpAspect.class);
@Pointcut("execution (public * com.sayhello.sayhello.controller.GirlController.*(..))")
public void log(){
}
@Before("log()")
public void doBefore(JoinPoint joinPoint){
ServletRequestAttributes attributes = (ServletRequestAttributes)RequestContextHolder.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
//url
logger.info("url:{}",request.getRequestURL());
//Method
logger.info("method:{}",request.getMethod());
//ip
logger.info("ip:{}",request.getRemoteAddr());
//class_method
logger.info("class_method:{}",joinPoint.getSignature().getDeclaringTypeName()+"."+joinPoint.getSignature().getName());
//args
logger.info("args:{}",joinPoint.getArgs());
}
@After("log()")
public void doAfter(){
logger.info("After");
}
@AfterReturning(pointcut = "log()",returning = "object")
public void doAfterReturning(Object object){
//logger.info("object:{}",object.toString());
}
}