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

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

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

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

AspectJ作為語言級別的AOP框架,功能相比于SpringAOP更加強(qiáng)大。SpringAOP旨在提供給用戶一個(gè)輕量級的AOP實(shí)現(xiàn)方案,它只能應(yīng)用在SpringIOC容器中管理的bean。而AspectJ旨在提供給用戶一個(gè)完整的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 //表示它是一個(gè)切面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)文章:
主站蜘蛛池模板: 1级a的观看视频 | 国产三级视频在线 | 国产黄色小视频在线观看 | 精品久久久久久亚洲 | 久久久久久久免费视频 | 成人网久久 | 国产视频合集 | 欧洲一级鲁丝片免费 | 丝袜足液精子免费视频 | 国产一区中文字幕在线观看 | 中文字幕区 | 婷婷丁香花麻豆 | 久久精品国产国产 | 99视频一区 | 久久超级碰 | 欧美午夜成年片在线观看 | 怡红院免费va男人的天堂 | 视频一区二区三区自拍 | 成人看片免费 | 日韩在线欧美 | 国产盗摄精品一区二区三区 | 欧美成人三级视频 | 午夜精品亚洲 | 亚洲精品国产专区91在线 | a级成人高清毛片 | 天天欲色成人综合网站 | 一区二区不卡在线 | 国产高清一 | 男女乱淫免费视频 | 97国产成人精品免费视频 | 久久国产精品自线拍免费 | 男女午夜性爽快免费视频不卡 | a级成人毛片久久 | 成人黄色在线观看 | 在线人成精品免费视频 | 国产综合亚洲专区在线 | 色老头老太做爰视频在线观看 | 免费看黄色的网址 | 一级做a爱久久久久久久 | 一区二区三区成人 | 午夜两性视频 |