pom文件引入以下依赖
<!-- AOP -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
添加全局的WebLogAspect类
@Aspect
@Component
public class WebLogAspect {
private static Logger logger = Logger.getLogger(WebLogAspect.class);
@Pointcut("execution(public * cn.com.javakf.controller..*.*(..))")
public void webLog() {
}
@Before("webLog()")
public void doBefore(JoinPoint joinPoint) throws Throwable {
// 接收到请求,记录请求内容
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
logger.info("#####################请求开始####################");
// 记录下请求内容
logger.info("URL : " + request.getRequestURL().toString());
logger.info("HTTP_METHOD : " + request.getMethod());
logger.info("IP : " + request.getRemoteAddr());
Enumeration<String> enu = request.getParameterNames();
while (enu.hasMoreElements()) {
String name = (String) enu.nextElement();
logger.info("name:{" + name + "},value:{" + request.getParameter(name) + "}");
}
}
@AfterReturning(returning = "ret", pointcut = "webLog()")
public void doAfterReturning(Object ret) throws Throwable {
// 处理完请求,返回内容
logger.info("RESPONSE : " + ret);
logger.info("#####################请求结束####################");
}
}
@Pointcut("execution(public * cn.com.javakf.controller..*.*(..))")
上面这段注解的意思如下:
- execution(): 表达式主体
- 第一个public *号:表示返回类型, *号表示所有的类型。
- 包名:表示需要拦截的包名,后面的两个句点表示当前包和当前包的所有子包,cn.com.javakf.controller包、子孙包下所有类的方法。
- 第二个*号:表示类名,*号表示所有的类。
*(..)
:最后这个星号表示方法名,*号表示所有的方法,后面括弧里面表示方法的参数,两个句点表示任何参数
代码托管:springboot_aop