SpringAOP中基于注解實(shí)現(xiàn)通用日志打印方法詳解
前言
我們?cè)谌粘i_(kāi)發(fā)中,項(xiàng)目里日志是必不可少的,一般有業(yè)務(wù)日志,數(shù)據(jù)庫(kù)日志,異常日志等,主要用于幫助程序猿后期排查一些生產(chǎn)中的bug。
有時(shí)候程序猿們?cè)谧龃a調(diào)優(yōu)的時(shí)候需要關(guān)注每個(gè)接口的響應(yīng)速度,所以需要打印接口調(diào)用時(shí)間,如果在接口中每次寫這段代碼實(shí)在惡心,故基于Spring AOP面向切面編程使用注解解決該問(wèn)題。
1.定義注解
value為對(duì)應(yīng)的接口名稱,默認(rèn)為BaseController
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface OwnLog {
String value() default "BaseController";
}2.面向切面處理
@Aspect
@Component
@Slf4j
public class LogAspect {
@Before(value = "@annotation(ownLog)")
public void before(JoinPoint point, OwnLog ownLog) {
//point.getArgs()獲取請(qǐng)求參數(shù)
log.info("服務(wù){(diào)}調(diào)用開(kāi)始,請(qǐng)求參數(shù):{}", ownLog.value(), JSONObject.toJSONString(point.getArgs()));
}
@Around(value = "@annotation(ownLog)")
public Object around(ProceedingJoinPoint point, OwnLog ownLog) {
Object result = null;
String name = ownLog.value();
long start = System.currentTimeMillis();
try {
result = point.proceed();
} catch (Throwable throwable) {
throwable.printStackTrace();
} finally {
long end = System.currentTimeMillis();
log.info(String.format("服務(wù)%s,耗時(shí):%dms", name, (end - start)));
}
return result;
}
//設(shè)置rvt為返回參數(shù)
@AfterReturning(value = "@annotation(ownLog)", returning = "rvt")
public void afterReturning(JoinPoint point, OwnLog ownLog, Object rvt) {
log.info("服務(wù){(diào)}調(diào)用結(jié)束,response:{}", ownLog.value(), JSONObject.toJSONString(rvt));
}
}3.使用注解
@OwnLog("sendMsg")
@Idempotent
@ApiOperation(value = "消息推送")
@PostMapping(value = "/sendMsg")
public BaseResp sendMessage(@ModelAttribute UserMsgHistoryDTO userMsgHistoryDTO) {
userMsgHistoryService.sendMessage(findCurrentUser(), userMsgHistoryDTO);
addUserLog(LOG_TYPE_USER, "用戶消息推送", JSON.toJSONString(userMsgHistoryDTO));
return new BaseResp<>(ResultStatus.SUCCESS);
}4.控制臺(tái)打印
輸出:
服務(wù)addEnrolmentUser調(diào)用開(kāi)始,request:[{"age":0,"country":"string","health":"一般","idNum":"12345","name":"string","phoneNum":"string","status":"審核中"}]
服務(wù)addEnrolmentUser,耗時(shí):13ms
服務(wù)addEnrolmentUser調(diào)用結(jié)束,response:{"code":10000,"message":"操作成功","success":true}
到此這篇關(guān)于SpringAOP中基于注解實(shí)現(xiàn)通用日志打印方法詳解的文章就介紹到這了,更多相關(guān)SpringAOP注解實(shí)現(xiàn)日志打印內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Spring源碼報(bào)錯(cuò)java:找不到類 InstrumentationSavingAgent的問(wèn)題
這篇文章主要介紹了使用Spring源碼報(bào)錯(cuò)java:找不到類 InstrumentationSavingAgent的問(wèn)題,本文給大家分享解決方法,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
SpringBoot Aop 詳解和多種使用場(chǎng)景解析
aop面向切面編程,是編程中一個(gè)很重要的思想本篇文章主要介紹的是SpringBoot切面Aop的使用和案例,對(duì)SpringBoot Aop相關(guān)知識(shí)感興趣的朋友跟隨小編一起看看吧2021-08-08
解決idea 通過(guò)build project 手動(dòng)觸發(fā)熱部署失敗的問(wèn)題
在debug運(yùn)行項(xiàng)目的過(guò)程中,并且保證(不添加方法,不修改方法名)一定的規(guī)則的情況下,可以通過(guò)build project 來(lái)手動(dòng)熱部署項(xiàng)目,本文給大家介紹解決idea 通過(guò)build project 手動(dòng)觸發(fā)熱部署失敗的問(wèn)題,感興趣的朋友一起看看吧2023-12-12

