您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

SpringBoot使用Aop记录请求日志

时间:2022-07-07 11:02:19  来源:  作者:先欠一个名字
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.*;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import JAVAx.servlet.http.HttpServletRequest;
import java.lang.reflect.Method;
import java.lang.reflect.Parameter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * 统一日志处理切面
 */
@Aspect
@Component
@Order(1)//定义Spring容器加载bean的顺序
public class WebLogAspect {

    //定义切点表达式,指定通知功能被应用的范围
    @Pointcut("execution(public * com.xxmfl.mp.sichao.controller.*.*(..))")
    public void webLog() {
    }

    @Before("webLog()")
    public void doBefore(JoinPoint joinPoint) throws Throwable {
    }

    /**value切入点位置
     * returning 自定义的变量,标识目标方法的返回值,自定义变量名必须和通知方法的形参一样
     * 特点:在目标方法之后执行的,能够获取到目标方法的返回值,可以根据这个返回值做不同的处理
     */
    @AfterReturning(value = "webLog()", returning = "ret")
    public void doAfterReturning(Object ret) throws Throwable {
    }

    //通知包裹了目标方法,在目标方法调用之前和之后执行自定义的行为
    //ProceedingJoinPoint切入点可以获取切入点方法上的名字、参数、注解和对象
    @Around("webLog()")
    public Object doAround(ProceedingJoinPoint joinPoint) throws Throwable
    {
        long startTime = System.currentTimeMillis();
        //获取当前请求对象
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        //前面是前置通知,后面是后置通知
        Object result = joinPoint.proceed();
        Signature signature = joinPoint.getSignature();
        MethodSignature methodSignature = (MethodSignature) signature;
        Method method = methodSignature.getMethod();
        long endTime = System.currentTimeMillis();
        System.out.println(request.getMethod()); //请求方式
        System.out.println(getParameter(method, joinPoint.getArgs())); //请求参数
        System.out.println(result);//返回结果
        System.out.println((int) (endTime - startTime)); //响应时间
        System.out.println(request.getRequestURL().toString());//请求路径
        //存入数据库记录
        return result;
    }

    /**
     * 根据方法和传入的参数获取请求参数
     */
    private Object getParameter(Method method, Object[] args)
    {
        List<Object> argList = new ArrayList<>();
        Parameter[] parameters = method.getParameters();
        for (int i = 0; i < parameters.length; i++) {
            //将RequestBody注解修饰的参数作为请求参数
            RequestBody requestBody = parameters[i].getAnnotation(RequestBody.class);
            if (requestBody != null) {
                argList.add(args[i]);
            }
            //将RequestParam注解修饰的参数作为请求参数
            RequestParam requestParam = parameters[i].getAnnotation(RequestParam.class);
            if (requestParam != null) {
                Map<String, Object> map = new HashMap<>();
                String key = parameters[i].getName();
                if (!StringUtils.isEmpty(requestParam.value())) {
                    key = requestParam.value();
                }
                map.put(key, args[i]);
                argList.add(map);
            }
        }
        if (argList.size() == 0) {
            return null;
        } else if (argList.size() == 1) {
            return argList.get(0);
        } else {
            return argList;
        }
    }
}


Tags:SpringBoot   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
概念IOC:控制反转。从前需要在程序中创建对象实例;现在则通过一个外部的容器统一动态创建spring IOC 容器中的实例如何动态加载Condition:只有在特定条件满足时才加载举例 @Con...【详细内容】
2022-10-10  Tags: SpringBoot  点击:(93)  评论:(0)  加入收藏
简介在项目中,存在传递超大 json 数据的场景。直接传输超大 json 数据的话,有以下两个弊端 占用网络带宽,而有些云产品就是按照带宽来计费的,间接浪费了钱 传输数据大导致网络...【详细内容】
2022-10-10  Tags: SpringBoot  点击:(18)  评论:(0)  加入收藏
前言最近自己用Spring Cloud Alibaba做了一个微服务架构的项目,部署的时候遇到了难题:内存不够。目前该项目有7个微服务,因为我只有一台阿里云的服务器(2C 4G),所以我只能把所有...【详细内容】
2022-10-06  Tags: SpringBoot  点击:(21)  评论:(0)  加入收藏
关于NettyNetty 是一个利用 Java 的高级网络的能力,隐藏其背后的复杂性而提供一个易于使用的 API 的客户端/服务器框架。MAVEN依赖 <dependencies> <!-- https://mvnrepos...【详细内容】
2022-09-27  Tags: SpringBoot  点击:(21)  评论:(0)  加入收藏
因业务需要, 公司内需要使用 SpringBoot Starter 构建 SDK. 不同的是使用了更为灵活的 Kotlin 语言, 构建脚本也换成了 Kotlin Script. 框架: SpringBoot 业务代码语言: Kot...【详细内容】
2022-09-27  Tags: SpringBoot  点击:(25)  评论:(0)  加入收藏
一、下载MinIo的地址https://min.io/download#/windows二、如何进行启动 绝对路径\minio.exe server F:\Data --console-address ":9001" 访问页面http://192.168.1.100:90...【详细内容】
2022-09-26  Tags: SpringBoot  点击:(38)  评论:(0)  加入收藏
姿势1:ThreadLocal+TaskDecorator用户工具类/** *使用ThreadLocal存储共享的数据变量,如登录的用户信息 */public class UserUtils { private static final ThreadLocal<...【详细内容】
2022-09-16  Tags: SpringBoot  点击:(55)  评论:(0)  加入收藏
添加依赖 org.springframework.boot spring-boot-starter-logging 在yml配置文件中添加配置应用配置文件logging: config: classpath: logback.xml 配置logback.xml文件信...【详细内容】
2022-09-16  Tags: SpringBoot  点击:(94)  评论:(0)  加入收藏
Spring官方已不推荐使用Autowired字段/属性注入bean,,一些大公司的新项目也明令禁止使用了。1. 说明最近公司升级框架,由原来的spring framerwork 3.0升级到5.0,然后写代码的时...【详细内容】
2022-09-16  Tags: SpringBoot  点击:(53)  评论:(0)  加入收藏
最近在开发一个新项目,用的框架(中间件)比较多,所以最近的文章,都会以优雅的实战为主,也可以是框架(中间件)的简单DEMO。今天给大家带来EhCache在SpringBoot框架下使用实战。简介EhC...【详细内容】
2022-09-16  Tags: SpringBoot  点击:(62)  评论:(0)  加入收藏
▌简易百科推荐
大厂技术 坚持周更 精选好文本文为来自 教育-智能学习-前端团队成员的文章,已授权 ELab 发布。智能学习前端团队自创立以来,团队专注于打破大众对教育的刻板印象,突破固有的教...【详细内容】
2022-10-14  ELab  今日头条  Tags:Tauri   点击:(9)  评论:(0)  加入收藏
根据官方的文档说明:Spring Data JPA - Reference Documentation 可以在查询的参数后面添加 True 或 False 来进行查询。例如,如果需要对下面的参数进行查询:True findByAct...【详细内容】
2022-10-11  松鼠工厂  今日头条  Tags:Spring   点击:(11)  评论:(0)  加入收藏
使用过Spring Data操作ES的小伙伴应该有所了解,它只能实现一些非常基本的数据管理工作,一旦遇到稍微复杂点的查询,基本都要依赖ES官方提供的RestHighLevelClient,Spring Data只...【详细内容】
2022-10-11  Java编程指南    Tags:MyBatis   点击:(15)  评论:(0)  加入收藏
概念IOC:控制反转。从前需要在程序中创建对象实例;现在则通过一个外部的容器统一动态创建spring IOC 容器中的实例如何动态加载Condition:只有在特定条件满足时才加载举例 @Con...【详细内容】
2022-10-10  小技术酱  今日头条  Tags:Springboot   点击:(93)  评论:(0)  加入收藏
简介在项目中,存在传递超大 json 数据的场景。直接传输超大 json 数据的话,有以下两个弊端 占用网络带宽,而有些云产品就是按照带宽来计费的,间接浪费了钱 传输数据大导致网络...【详细内容】
2022-10-10    网易号  Tags:Springboot   点击:(18)  评论:(0)  加入收藏
简介Tokio 是 Rust 世界里最著名的异步执行框架,该框架包罗了几乎所有异步执行的接口,包括但不限于文件、网络和文件系统管理。在这些方便使用的高层接口之下则是一些“基石...【详细内容】
2022-10-07  达坦科技DateLord  今日头条  Tags:Tokio   点击:(17)  评论:(0)  加入收藏
/ 前言 /我收回标题上的话,从0手撸一个框架一点也不轻松,需要考虑的地方比较多,一些实现和细节值得商榷,是一个比较大的挑战,有不足的地方欢迎大佬们提供意见/ 依赖任务加载 /平...【详细内容】
2022-10-07  Meta多元宇宙  今日头条  Tags:框架   点击:(17)  评论:(0)  加入收藏
一、全局配置自定义1、代码配置 方式一:让父子上下文ComponentScan重叠(强烈不建议使用) @Configurationpublic class StockFeignConfiguration { /** * 日志级别...【详细内容】
2022-10-07  Java架构师知识  今日头条  Tags:Spring Cloud   点击:(14)  评论:(0)  加入收藏
摘要:本文介绍了Sermant Agent的接入原理和如何使用Sermant Agent无修改接入CSE。 本文分享自华为云社区《【技术干货】Spring Cloud应用零代码修改接入华为云微服务引擎CSE-...【详细内容】
2022-10-06  华为云开发者联盟  今日头条  Tags:Spring Cloud   点击:(19)  评论:(0)  加入收藏
此列表来自于State of JS的报告,该报告是对JavaScript社区开发人员的年度综合调查,旨在分享他们对库的使用和满意度的看法,以及围绕工具和社区内的概念和意见,几周前发布的 2021...【详细内容】
2022-10-06  慧都科技  今日头条  Tags:   点击:(27)  评论:(0)  加入收藏
站内最新
站内热门
站内头条