亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

SpringBoot使用Aspect切面攔截打印請求參數的示例代碼

瀏覽:89日期:2023-02-25 13:42:24

AspectJ作為語言級別的AOP框架,功能相比于SpringAOP更加強大。SpringAOP旨在提供給用戶一個輕量級的AOP實現方案,它只能應用在SpringIOC容器中管理的bean。而AspectJ旨在提供給用戶一個完整的AOP解決方案,它可以應用在所有的域對象中,下面給大家介紹SpringBoot使用Aspect切面攔截打印請求參數的代碼。

引入依賴

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

也用到了fastjson打印參數 , 如果引了就不需要(也可以根據自己的來打印)

<!-- 添加fastjson 支持 --><dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.15</version></dependency>

LogAspect.java

import com.alibaba.fastjson.JSON;import lombok.extern.slf4j.Slf4j;import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.Signature;import org.aspectj.lang.annotation.Around;import org.aspectj.lang.annotation.Aspect;import org.aspectj.lang.reflect.MethodSignature;import org.springframework.stereotype.Component;import org.springframework.web.context.request.RequestContextHolder;import org.springframework.web.context.request.ServletRequestAttributes;import javax.servlet.http.HttpServletRequest;import java.lang.reflect.Method;/** * @author zhipeih * @date 2021/07/14 */@Slf4j@Component@Aspect //表示它是一個切面public class LogAspect { /** * * execution:改成自己要打印的控制器路徑 * @param proceedingJoinPoint * @return * @throws Throwable */ @Around('execution(* com.example.*.controller.*.*(..)) ') public Object handleControllerMethod(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {//原始的HTTP請求和響應的信息ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletRequest request = attributes.getRequest();Signature signature = proceedingJoinPoint.getSignature();MethodSignature methodSignature = (MethodSignature)signature;//獲取當前執行的方法Method targetMethod = methodSignature.getMethod();//獲取參數Object[] objects = proceedingJoinPoint.getArgs();//獲取返回對象Object object = proceedingJoinPoint.proceed();StringBuilder sb = new StringBuilder(1000);sb.append('-------------------------------------------------------------n');sb.append('Controller: ').append(targetMethod.getDeclaringClass().getName()).append('n');sb.append('Method : ').append(targetMethod.getName()).append('n');sb.append('Params : ').append(JSON.toJSONString(objects)).append('n');sb.append('URI : ').append(request.getRequestURI()).append('n');sb.append('URL : ').append(request.getRequestURL()).append('n');sb.append('Return : ').append(object).append('n');sb.append('-------------------------------------------------------------n');System.out.println(sb);return proceedingJoinPoint.proceed(); }}

到此這篇關于SpringBoot使用Aspect切面攔截打印請求參數的文章就介紹到這了,更多相關SpringBoot打印請求參數內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 国产成人精品免费视频动漫 | 亚洲精品精品 | 在线看国产视频 | 日本一级特黄毛片高清视频 | 日本欧美高清 | 国产在线观看第一页 | 国产欧美亚洲精品第3页在线 | 一级做a爰片性色毛片2021 | 国产福利在线永久视频 | 美女视频黄a视频全免费网站一区 | 亚洲图区综合网 | 97一级毛片全部免费播放 | 亚洲欧美日韩在线线精品 | 久久精品国产免费高清 | 免费免费啪视频在线 | 午夜成年免费观看视频 | 青青热久麻豆精品视频在线观看 | 日韩videossex另类 | 国产a国产 | 91短视频版高清在线观看免费 | 亚洲 自拍 欧美 另类小说 | 大ji吧快给我别停受不了视频 | 成人欧美一区二区三区在线 | 国内精品在线播放 | 一级毛片特级毛片免费的 | 亚洲91视频 | 婷婷亚洲五月色综合 | 免费播放观看视频大片 | 日韩一区二区三区免费体验 | 最新亚洲手机在线人成网站 | 国产日韩亚洲欧洲一区二区三区 | 8x8x国产 | 久久www免费人成_看 | 高清国产美女一级a毛片在线 | 一区二区国产一区二区a4yy | 欧洲黄色网 | 国产精品黄色大片 | 原味小视频在线www国产 | 成人网免费看 | 奇米网狠狠网 | 国产露脸国语对白在线 |