Spring Boot运用(一)Spring Boot添加切面,记录日志

阅读: 评论:0

Spring Boot运用(一)Spring Boot添加切面,记录日志

Spring Boot运用(一)Spring Boot添加切面,记录日志

一、AOP简介

AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是Spring框架中的一个重要内容,

它通过对既有程序定义一个切入点,然后在其前后切入不同的执行内容,比如常见的有:打开数据库连接/关闭数据库连接、打开事务/关闭事务、记录日志等。基于AOP不会破坏原

来程序逻辑,因此它可以很好的对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。

下面主要讲两个内容,一个是如何在Spring Boot中引入Aop功能,二是如何使用Aop做切面去统一处理Web请求的日志。

 

二、修改l

	<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency>

三、实现Web层的日志切面

而当我们需要使用CGLIB来实现AOP的时候,需要配置spring.aop.proxy-target-class=true,不然默认使用的是标准Java的实现。

实现AOP的切面主要有以下几个要素:

  • 使用@Aspect注解将一个java类定义为切面类
  • 使用@Pointcut定义一个切入点,可以是一个规则表达式,比如下例中某个package下的所有函数,也可以是一个注解等。
  • 根据需要在切入点不同位置的切入内容
    • 使用@Before在切入点开始处切入内容
    • 使用@After在切入点结尾处切入内容
    • 使用@AfterReturning在切入点return内容之后切入内容(可以用来对处理返回值做一些加工处理)
    • 使用@Around在切入点前后切入内容,并自己控制何时执行切入点自身的内容
    • 使用@AfterThrowing用来处理当切入内容部分抛出异常之后的处理逻辑
import java.util.Arrays;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.apachemons.lang.StringUtils;
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.stereotype.Component;
import org.t.request.RequestContextHolder;
import org.t.request.ServletRequestAttributes;/*** 项目日志 切面* @author zengdq* 2019年1月5日*/
@Aspect
@Component
public class WebLogAspect {private static final Logger logger = Logger(WebLogAspect.class);private static final String PLATFORM_NAME = "xxx项目名称";/*** 统计时间*/ThreadLocal<Long> startTime = new ThreadLocal<>();@Pointcut("execution(public * ller..*.*(..))")public void webLog(){}@Before("webLog()")public void doBefore(JoinPoint joinPoint) throws Throwable {startTime.set(System.currentTimeMillis());// 接收到请求,记录请求内容ServletRequestAttributes attributes = (ServletRequestAttributes) RequestAttributes();HttpServletRequest request = Request();//打印请求参数Map<String, String[]> paramMap = ParameterMap();if(paramMap != null && paramMap.size() > 0) {StringBuffer paramSbf = new StringBuffer();for(String mapKey:paramMap.keySet()) {String[] mapValue = (mapKey);//添加判断if(mapValue != null && mapValue.length > 0) {for(String paramStr:mapValue) {if(StringUtils.isNotBlank(paramStr)) {paramSbf.append("参数"+mapKey+"=");paramSbf.append(paramStr);paramSbf.append(";");}}}//END if}//END for//打印日志参数logger.info(PLATFORM_NAME+"-->request请求参数PARAM : " + paramSbf);}//END if        // 记录下请求内容logger.info(PLATFORM_NAME+"-->request请求URL : " + RequestURL().toString());logger.info(PLATFORM_NAME+"-->request请求方法HTTP_METHOD : " + Method());logger.info(PLATFORM_NAME+"-->request请求方法IP : " + getIP(request));logger.info(PLATFORM_NAME+"-->request请求类方法CLASS_METHOD : " + Signature().getDeclaringTypeName() + "." + Signature().getName());logger.info(PLATFORM_NAME+"-->request请求ARGS : " + Args()));}@AfterReturning(returning = "ret", pointcut = "webLog()")public void doAfterReturning(Object ret) throws Throwable {// 处理完请求,返回内容logger.info(PLATFORM_NAME+"-->response请求响应结果RESULT: " + ret);logger.info(PLATFORM_NAME+"-->response请求响应时间= 【" + (System.currentTimeMillis() - ())+"】毫秒");}/*** * @param request* @return*/private static String getIP(HttpServletRequest request) {String ip = Header("x-forwarded-for");if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {ip = Header("Proxy-Client-IP");}if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {ip = Header("WL-Proxy-Client-IP");}if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {ip = RemoteAddr();}return ip;}
}

 

本文发布于:2024-02-02 16:20:07,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170686200644972.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:切面   日志   Spring   Boot
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23