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

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

SpringBoot AOP處理請求日志打印功能代碼實例

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

設計原則和思路:

元注解方式結合AOP,靈活記錄操作日志 能夠記錄詳細錯誤日志為運營以及審計提供支持 日志記錄盡可能減少性能影響 操作描述參數支持動態獲取,其他參數自動記錄。

代碼實例如下

@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() { } /** * 前置通知:在某連接點之前執行的通知,但這個通知不能阻止連接點之前的執行流程(除非它拋出一個異常)。 * * @param joinPoint 參數 */ @Before('controllerMethodPointcut()') public void before(JoinPoint joinPoint) { START_TIME_MILLIS.set(System.currentTimeMillis()); } /** * 后置通知:在某連接點正常完成后執行的通知,通常在一個匹配的方法返回的時候執行。 * * @param joinPoint 參數 */ @AfterReturning(value = 'controllerMethodPointcut()', returning = 'result') public void afterReturning(JoinPoint joinPoint, Object result) { String logTemplate = '--------------- 執行成功 ---------------n請求開始---Send Request URL: {}, Method: {}, Params: {} n請求方法---ClassName: {}, [Method]: {}, execution time: {}ms n請求結束---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(); } /** * 異常通知:在方法拋出異常退出時執行的通知。 * * @param joinPoint 參數 */ @AfterThrowing(value = 'controllerMethodPointcut()', throwing = 'ex') public void afterThrowing(JoinPoint joinPoint, Throwable ex) { String logTemplate = '--------------- 執行失敗 ---------------n異常請求開始---Send Request URL: {}, Method: {}, Params: {} n異常請求方法---ClassName: {}, [Method]: {}, execution time: {}ms n異常請求結束---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(); } /** * 最終通知。當某連接點退出的時候執行的通知(不論是正常返回還是異常退出)。 * * @param joinPoint */ @After('controllerMethodPointcut()') public void after(JoinPoint joinPoint) { }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 综合久久精品 | 一级做a爰片性色毛片思念网 | 91国自产精品中文字幕亚洲 | 九一精品| 欧美一区二区在线视频 | 一级a级毛片 | 久久综合精品视频 | 国产成人啪精品午夜在线观看 | 国产情侣露脸 | 大学生久久香蕉国产线看观看 | 看黄a大片 免费 | 综合精品一区 | 精品国产高清a毛片无毒不卡 | 中文字幕在线观 | 亚洲黄色自拍 | 韩国xxxxxxxx69| 日韩小视频网站 | 91精品乱码一区二区三区 | 欧美一级做a爰片免费 | 97se狠狠狠狠狼亚洲综合网 | 999香蕉视频 | 亚洲 欧美 国产 日韩 制服 bt | 欧美在线成人午夜网站 | 久久国产热视频 | 成年美女黄网站色大免费视频 | 欧美在线一级精品 | 成人在线视频网址 | 国产精品xxx | 日韩一卡2卡3卡四区别 | 午夜视频福利在线 | 在线成人天天鲁夜啪视频 | 一级做a爰片性色毛片小说 一级做a爰片性色毛片中国 | 大尺度做爰床戏呻吟免费观看91 | 在线观看网站黄 | 黄色毛片视频在线观看 | 久久在视频 | 黄色片网站免费 | 国产精品免费小视频 | 国产成人影院 | 东莞a级毛片 | 欧美日韩系列 |