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

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

SpringBoot AOP處理請(qǐng)求日志打印功能代碼實(shí)例

瀏覽:15日期:2023-05-26 16:54:47

設(shè)計(jì)原則和思路:

元注解方式結(jié)合AOP,靈活記錄操作日志 能夠記錄詳細(xì)錯(cuò)誤日志為運(yùn)營(yíng)以及審計(jì)提供支持 日志記錄盡可能減少性能影響 操作描述參數(shù)支持動(dòng)態(tài)獲取,其他參數(shù)自動(dòng)記錄。

代碼實(shí)例如下

@Slf4j@Aspect@Configurationpublic class RequestAopConfig { @Autowired private HttpServletRequest request; private static final ThreadLocal<Long> START_TIME_MILLIS = new ThreadLocal<>(); @Pointcut('execution(* com.xxx.xxx.xxx..*(..)) ' + '&&(@annotation(org.springframework.web.bind.annotation.PostMapping)' + '||@annotation(org.springframework.web.bind.annotation.GetMapping)' + '||@annotation(org.springframework.web.bind.annotation.PutMapping)' + '||@annotation(org.springframework.web.bind.annotation.DeleteMapping))') public void controllerMethodPointcut() { } /** * 前置通知:在某連接點(diǎn)之前執(zhí)行的通知,但這個(gè)通知不能阻止連接點(diǎn)之前的執(zhí)行流程(除非它拋出一個(gè)異常)。 * * @param joinPoint 參數(shù) */ @Before('controllerMethodPointcut()') public void before(JoinPoint joinPoint) { START_TIME_MILLIS.set(System.currentTimeMillis()); } /** * 后置通知:在某連接點(diǎn)正常完成后執(zhí)行的通知,通常在一個(gè)匹配的方法返回的時(shí)候執(zhí)行。 * * @param joinPoint 參數(shù) */ @AfterReturning(value = 'controllerMethodPointcut()', returning = 'result') public void afterReturning(JoinPoint joinPoint, Object result) { String logTemplate = '--------------- 執(zhí)行成功 ---------------n請(qǐng)求開(kāi)始---Send Request URL: {}, Method: {}, Params: {} n請(qǐng)求方法---ClassName: {}, [Method]: {}, execution time: {}ms n請(qǐng)求結(jié)束---Send Response Result: {}'; log.info(logTemplate, request.getRequestURL(), request.getMethod(), JSON.toJSONString(joinPoint.getArgs()), joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName(), (System.currentTimeMillis() - START_TIME_MILLIS.get()), JSON.toJSONString(result)); START_TIME_MILLIS.remove(); } /** * 異常通知:在方法拋出異常退出時(shí)執(zhí)行的通知。 * * @param joinPoint 參數(shù) */ @AfterThrowing(value = 'controllerMethodPointcut()', throwing = 'ex') public void afterThrowing(JoinPoint joinPoint, Throwable ex) { String logTemplate = '--------------- 執(zhí)行失敗 ---------------n異常請(qǐng)求開(kāi)始---Send Request URL: {}, Method: {}, Params: {} n異常請(qǐng)求方法---ClassName: {}, [Method]: {}, execution time: {}ms n異常請(qǐng)求結(jié)束---Exception Message: {}'; log.error(logTemplate, request.getRequestURL(), request.getMethod(), JSON.toJSONString(joinPoint.getArgs()), joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName(), (System.currentTimeMillis() - START_TIME_MILLIS.get()), ex.getMessage()); START_TIME_MILLIS.remove(); } /** * 最終通知。當(dāng)某連接點(diǎn)退出的時(shí)候執(zhí)行的通知(不論是正常返回還是異常退出)。 * * @param joinPoint */ @After('controllerMethodPointcut()') public void after(JoinPoint joinPoint) { }}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 全部aⅴ极品视觉盛宴精品 全部免费a级毛片 | 国产一区二区三区在线免费 | 精品综合在线 | 999久久| 免费特黄一级欧美大片 | 亚洲大片免费观看 | 亚洲一区二区免费看 | 久久综合伊人77777 | 欧美午夜伦y4480私人影院 | 免费观看成年人网站 | 欧美日韩ay在线观看 | 天天看a | 国产亚洲一区二区三区在线观看 | 久草久 | 中国美女隐私无遮挡免费视频 | 国产亚洲精品久久综合影院 | 国产短裙黑色丝袜在线观看下 | 2022国内精品免费福利视频 | 欧美一级日韩一级亚洲一级 | 国产精品1区2区3区在线播放 | 日韩中文字幕免费观看 | 韩国一级性生活片 | 国产欧美精品一区二区三区 | 性欧美高清come | 国产精品看片 | 欧美视频一区二区 | 欧美精品伊人久久 | 国产成人一区二区三区高清 | 网友自拍第一页 | 国产国产人免费视频成69堂 | 日本尹人综合香蕉在线观看 | 99热精品在线免费观看 | 女人张开腿等男人桶免费视频 | 久久久久久久亚洲精品一区 | 国产裸体美女视频全黄 | 久久久久久免费精品视频 | 深夜做爰性大片中文 | 性做久久久久久 | 亚洲精品乱无伦码 | 国产短视频精品一区二区三区 | 久久国产精品免费一区二区三区 |