springboot如何使用AOP做访问请求日志
作者:闻窗 发布时间:2023-11-11 10:12:19
标签:spring,boot,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 : ------------------------请求信息---------------------------------
这里只做访问请求的日志打印,还可以后置通知,打印响应信息,结合环绕通知可以打印程序执行的时间等其他操作。
来源:https://www.cnblogs.com/tdyang/p/12142177.html
0
投稿
猜你喜欢
- 一、简介ThreadPool相比Thread来说具备了很多优势,但是ThreadPool却又存在一些使用上的不方便。比如:Task支持线程的
- 1、修改maven的pom文件只需要将如下依赖添加到pom.xml文件中即可。(注意此处是以plugin的方式,放在<plugins&
- JAVA简单写学生信息管理系统,实现学生信息的输入、查询、修改、删除操作package Week;import jdk.internal.u
- mkdir函数用于创建目录。格式如下:#include<sys/types.h>#include<sys/stat.h&g
- 在使用springMVC框架构建web应用,客户端常会请求字符串、整型、json等格式的数据,通常使用@ResponseBody注解使 co
- android线程消息机制主要由Handler,Looper,Message和MessageQuene四个部分组成。平常在开发中,我们常用来
- 话不多说,请看实例代码String ip = request.getHeader("x-forwarded-for");
- 在spring中有很多以XXXAware命名的接口,很多人也不清楚这些接口都是做什么用的,这篇文章将描述常用的一些接口。一,Applicat
- 题目描述Java创建线程的几种方式Java使用Thread类代表线程,所有线程对象都必须是Thread类或者其子类的实例。Java可以用以下
- Java8新特性系列我们已经介绍了Stream、Lambda表达式、DateTime日期时间处理,最后以“NullPointerExcept
- /// <summary> /// 遍历Co
- java.lang.ArrayStoreException 分析这个demo来说明怎样排查一个spring boot 1应用升级到sprin
- 前言本文的记录如何用CustomPaint、GestureDetector实现一个进度条控件。首先需要说明的是 flutter Materi
- 在java.lang.Runtime.exec的使用中,我们经常会用到将重定向命令执行的输入/结果或者将错误信息读取出来.那么,在使用过程中
- FTP(File Transfer Protocol)就是文件传输协议。通过FTP客户端从远程FTP服务器上拷贝文件到本地计算机称为下载,将
- 最近做一个需求,需求中的bean只用于生成一次json使用,所以想通过配置来动态的生成,查了一下,java还真有这个实现。java动态的生成
- 前言这里主要简单介绍如何使用Camera+SurfaceView自定义相机拍照,如果是Camera2或者是TextureView的可以前往主
- 说明:本文记录如何在Idea下,利用Maven管理项目,并整合SSM(Spring + Spring MVC +Mybatis)框架,实现简
- 前几天在跟公司大佬讨论一个问题时,看到他使用Handler的一种方式,旁边的同事在说:以前不是这么用的啊。这个问题引发了我的好奇,虽然当时翻
- 前言:什么是JDBCJava 数据库连接,(Java Database Connectivity,简称JDBC)是Java语言中用来规范客户