色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

AspectJ作為語言級別的AOP框架,功能相比于SpringAOP更加強大。SpringAOP旨在提供給用戶一個輕量級的AOP實現(xiàn)方案,它只能應(yīng)用在SpringIOC容器中管理的bean。而AspectJ旨在提供給用戶一個完整的AOP解決方案,它可以應(yīng)用在所有的域?qū)ο笾校旅娼o大家介紹SpringBoot使用Aspect切面攔截打印請求參數(shù)的代碼。

引入依賴

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

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

<!-- 添加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請求和響應(yīng)的信息ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletRequest request = attributes.getRequest();Signature signature = proceedingJoinPoint.getSignature();MethodSignature methodSignature = (MethodSignature)signature;//獲取當(dāng)前執(zhí)行的方法Method targetMethod = methodSignature.getMethod();//獲取參數(shù)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(); }}

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

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 欧美一区中文字幕 | 一本不卡| 久久精品视频99 | 欧美高清在线视频在线99精品 | 亚洲性xx | 日韩 亚洲 制服 欧美 综合 | 国产天堂亚洲精品 | 日本高清va不卡视频在线观看 | 国产美女视频一区 | 国产在线精品成人一区二区三区 | 黄色三级在线 | 色噜噜亚洲男人的天堂 | 国产初高中生粉嫩无套第一次 | 中文字幕日本不卡 | 一本色道久久综合亚洲精品加 | 国产午夜精品理论片影院 | 久久青草国产手机看片福利盒子 | 男人都懂的网址在线看片 | 久久成人国产精品免费 | 国产成人精品日本亚洲专区6 | 亚洲国产精品第一区二区三区 | 久久免费视频在线观看 | 亚洲精品一区二区三区不卡 | 深夜福利网址 | 2019国产精品 | 日韩一区二区三区四区 | 日本免费人成在线网站 | 欧美性猛交xxxx免费看手交 | 久久精品视频观看 | 国产亚洲精品影达达兔 | 欧美高清在线精品一区二区不卡 | 色资源二区在线视频 | 特级毛片在线播放 | 久久99热精品免费观看欧美 | 国产亚洲精品激情一区二区三区 | 毛片大全免费 | 国产成人久久精品推最新 | 欧美成人一级毛片 | 欧美成人精品大片免费流量 | 亚洲网址在线观看 | 国产99视频精品一区 |