springboot如何使用AOP做访问请求日志

 更新时间:2020年01月03日 10:28:54   作者:闻窗  
这篇文章主要介绍了springboot如何使用AOP做访问请求日志,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了springboot如何使用AOP做访问请求日志,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

springboot中使用AOP做访问请求日志:这次引入springboot的aop和日志

1、pom.xml引入:

<!--springBoot的aop,已经集成了spring aop和AspectJ-->
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-aop</artifactId>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-logging -->
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-logging</artifactId>
    </dependency>

2、切面类配置:

@Component
@Aspect
public class LogAspect {

  private static final Logger logger = LoggerFactory.getLogger(LogAspect.class);
  //切入点表达式,com.springboot.controller自己controller包的路径
  @Pointcut("execution(public * com.springboot.controller..*.*(..))")
  public void pointCut(){

  }

  @Before("pointCut()")
  public void beforeMethod(JoinPoint joinPoint){
    ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes)RequestContextHolder.getRequestAttributes();

    HttpServletRequest request = servletRequestAttributes.getRequest();

      //获取需要打印的参数信息
    String requestURI = request.getRequestURI();
    String method = request.getMethod();
    String remoteAddr = request.getRemoteAddr();
     //这里使用的是阿里的fastjson
    String jsonString = JSON.toJSONString(joinPoint.getArgs());

      //打印信息
    logger.info("------------------------请求信息----------------------------------");
    logger.info("请求时间 :{}",new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
    logger.info("remoteAddr: {} ",remoteAddr);
    logger.info("requestURI : {}",requestURI);
    logger.info("Controller : {}", joinPoint.getTarget().getClass());
    logger.info("method type: {}" ,method);
    logger.info("req paras: {}",jsonString);
    logger.info("------------------------请求信息-----------------------------------");
  }
}

效果:

com.springboot.common.aop.LogAspect   : ------------------------请求信息----------------------------------
 com.springboot.common.aop.LogAspect   : 请求时间 :2020-01-02 22:38:40
 com.springboot.common.aop.LogAspect   : remoteAddr: 0:0:0:0:0:0:0:1 
 com.springboot.common.aop.LogAspect   : requestURI : /user/10001
 com.springboot.common.aop.LogAspect   : Controller : class com.springboot.controller.UserController
 com.springboot.common.aop.LogAspect   : method type: GET
 com.springboot.common.aop.LogAspect   : req paras: [10001]
 com.springboot.common.aop.LogAspect   : ------------------------请求信息---------------------------------

这里只做访问请求的日志打印,还可以后置通知,打印响应信息,结合环绕通知可以打印程序执行的时间等其他操作。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 解读@Scheduled任务调度/定时任务非分布式

    解读@Scheduled任务调度/定时任务非分布式

    这篇文章主要介绍了解读@Scheduled任务调度/定时任务非分布式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Java超详细分析抽象类和接口的使用

    Java超详细分析抽象类和接口的使用

    在类中没有包含足够的信息来描绘一个具体的对象,这样的类称为抽象类,接口是Java中最重要的概念之一,它可以被理解为一种特殊的类,不同的是接口的成员没有执行体,是由全局常量和公共的抽象方法所组成,本文给大家介绍Java抽象类和接口,感兴趣的朋友一起看看吧
    2022-04-04
  • Java字符拼接成字符串的注意点详解

    Java字符拼接成字符串的注意点详解

    这篇文章主要介绍了Java字符拼接成字符串的注意点详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • Java 反射机制实例详解

    Java 反射机制实例详解

    这篇文章主要介绍了Java 反射机制实例详解的相关资料,这里对java中反射机制进行了详细的分析,需要的朋友可以参考下
    2017-09-09
  • java客户端登陆服务器用户名验证

    java客户端登陆服务器用户名验证

    这篇文章主要为大家详细介绍了java客户端登陆服务器用户名验证的相关资料,需要的朋友可以参考下
    2016-05-05
  • 浅谈多线程中的锁的几种用法总结(必看)

    浅谈多线程中的锁的几种用法总结(必看)

    下面小编就为大家带来一篇浅谈多线程中的锁的几种用法总结(必看)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • Kotlin 基础教程之泛型

    Kotlin 基础教程之泛型

    这篇文章主要介绍了Kotlin 基础教程之泛型的相关资料,需要的朋友可以参考下
    2017-06-06
  • 使用java数组 封装自己的数组操作示例

    使用java数组 封装自己的数组操作示例

    这篇文章主要介绍了使用java数组 封装自己的数组操作,结合实例形式分析了java数组索引、遍历等相关封装操作技巧与注意事项,需要的朋友可以参考下
    2020-03-03
  • JUC并发编程LinkedBlockingQueue队列深入分析源码

    JUC并发编程LinkedBlockingQueue队列深入分析源码

    LinkedBlockingQueue 是一个可选有界阻塞队列,这篇文章主要为大家详细介绍了Java中LinkedBlockingQueue的实现原理与适用场景,感兴趣的可以了解一下
    2023-04-04
  • SpringMVC适配器模式作用范围介绍

    SpringMVC适配器模式作用范围介绍

    适配器这个词我们应该很熟悉,天天都在使用,手机充电时,电源线头头就叫电源适配器,干什么用的呢?把220V电压转换成手机充电时使用的电压,那么适配器是不是很好理解了,下面看一下
    2023-04-04

最新评论