使用Java實(shí)現(xiàn)接口攔截器來(lái)監(jiān)控接口的執(zhí)行情況
在工作中,我們往往會(huì)遇到一些接口的報(bào)錯(cuò),在排查問(wèn)題的時(shí)候,由于沒(méi)有對(duì)接口的執(zhí)行情況,以及入?yún)⑦M(jìn)行監(jiān)控,所以排查起問(wèn)題就特別費(fèi)勁,今天我們就一起來(lái)寫一個(gè)接口的攔截器。
@Slf4j
@Aspect
@Component
public class LogAspect {
@SneakyThrows
@Around("execution(* cn.com.alliance.we.controller..*(..))")
public Object doAround(ProceedingJoinPoint pjp){
// 創(chuàng)造計(jì)時(shí)器
Stopwatch stWatch = Stopwatch.createStarted();
//獲取請(qǐng)求信息
ServletRequestAttributes sra = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
HttpServletRequest request = sra.getRequest();
String tenantId = "unknown";
try {
tenantId = TenantContextHolder.getTenantId().toLowerCase(Locale.ROOT);
}catch (Exception e){
log.error("LogAspect獲取租戶異常:", e);
}
//獲取請(qǐng)求地址
String requestURI = request.getRequestURI();
//組合請(qǐng)求參數(shù),進(jìn)行日志打印
Object[] objects = pjp.getArgs();
Object[] arguments = new Object[objects.length];
for (int i = 0; i < objects.length; i++) {
if (objects[i] instanceof ServletRequest || objects[i] instanceof ServletResponse || objects[i] instanceof MultipartFile) {
//過(guò)濾掉不能序列化的參數(shù)
continue;
}
arguments[i] = objects[i];
}
//獲取登錄信息
OcManageUser currentUserOrNull = OcManageUserContext.getCurrentUserOrNull();
String currentOrgCode = "Unknown";
String currentEmpCode = "Unknown";
if(currentUserOrNull != null){
currentOrgCode = currentUserOrNull.getOrgCode();
currentEmpCode = currentUserOrNull.getEmpCode();
}
Object result = null;
try {
result = pjp.proceed();
//請(qǐng)求操作成功
String resultJosnString = "";
if (result != null) {
try{
resultJosnString = JsonUtil.bean2Json(result);
}catch (Exception e){
resultJosnString = String.valueOf(result);
}
}
//記錄請(qǐng)求完成執(zhí)行時(shí)間:
long usedTime = stWatch.elapsed(TimeUnit.MILLISECONDS);
//記錄日志
if (log.isInfoEnabled()) {
log.info("URI信息:{},租戶:{},登錄人:{},登錄網(wǎng)點(diǎn):{}, 耗時(shí):{},請(qǐng)求參數(shù):{}, 響應(yīng)參數(shù):{}", v("requestURI", requestURI),tenantId,currentEmpCode,currentOrgCode, v("elapsed", usedTime), JsonUtil.bean2Json(arguments), resultJosnString);
}
return result;
}catch (Throwable et){
//請(qǐng)求異常操作
//記錄請(qǐng)求完成執(zhí)行時(shí)間:
long usedTime = stWatch.elapsed(TimeUnit.MILLISECONDS);
//記錄日志
log.error("URI信息:{},租戶:{},登錄人:{},登錄網(wǎng)點(diǎn):{}, 耗時(shí):{},請(qǐng)求參數(shù):{}, 響應(yīng)異常信息:", v("requestURI", requestURI),tenantId,currentEmpCode,currentOrgCode, v("elapsed", usedTime), JsonUtil.bean2Json(arguments), et);
throw et;
}
}
}
寫這么一個(gè)攔截器并不復(fù)雜,主要的還是需要注意一些細(xì)節(jié),比如過(guò)濾掉一些不能序列化的參數(shù);還有就是可以根據(jù)自己的需要,將請(qǐng)求頭的參數(shù)也打印出來(lái)。
到此這篇關(guān)于使用Java實(shí)現(xiàn)接口攔截器來(lái)監(jiān)控接口的執(zhí)行情況的文章就介紹到這了,更多相關(guān)Java接口攔截器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot CommandLineRunner接口實(shí)現(xiàn)自動(dòng)任務(wù)加載功能
這篇文章主要介紹了springboot CommandLineRunner接口實(shí)現(xiàn)自動(dòng)任務(wù)加載功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
Java設(shè)計(jì)模式之工廠模式實(shí)現(xiàn)方法詳解
這篇文章主要介紹了Java設(shè)計(jì)模式之工廠模式實(shí)現(xiàn)方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了工廠模式的分類、原理、實(shí)現(xiàn)方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-12-12
java開(kāi)發(fā)實(shí)現(xiàn)訂閱到貨通知幫我們買到想買的東西
這篇文章主要為大家介紹了java開(kāi)發(fā)實(shí)現(xiàn)訂閱到貨通知幫我們買到想買的東西示例demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
SpringBoot中異常處理實(shí)戰(zhàn)記錄
在我們實(shí)際項(xiàng)目開(kāi)放中經(jīng)常需要我們處理很多的異常,如何在spring boot項(xiàng)目里面實(shí)現(xiàn)異常處理呢,下面這篇文章主要給大家介紹了關(guān)于SpringBoot中異常處理的相關(guān)資料,需要的朋友可以參考下2022-05-05
IDEA maven引入SSL證書校驗(yàn)問(wèn)題及處理
這篇文章主要討論了在Maven項(xiàng)目中遇到依賴導(dǎo)入問(wèn)題,特別是關(guān)于PKIX路徑構(gòu)建失敗的錯(cuò)誤,文章提供了三種解決方法:手動(dòng)下載依賴、忽略SSL證書校驗(yàn)以及生成并導(dǎo)入SSL證書,每種方法都有詳細(xì)的步驟和示例代碼,幫助開(kāi)發(fā)者解決這個(gè)問(wèn)題2025-02-02
詳解如何使用ModelMapper庫(kù)進(jìn)行對(duì)象之間的屬性映射
這篇文章主要介紹了如何使用ModelMapper庫(kù)進(jìn)行對(duì)象之間的屬性映射實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Spring Boot集成Thymeleaf模板引擎的完整步驟
這篇文章主要給大家介紹了關(guān)于Spring Boot集成Thymeleaf模板引擎的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02
java中優(yōu)化大量if...else...方法總結(jié)
在我們平時(shí)的開(kāi)發(fā)過(guò)程中,經(jīng)??赡軙?huì)出現(xiàn)大量If else的場(chǎng)景,代碼顯的很臃腫,非常不優(yōu)雅,下面這篇文章主要給大家介紹了關(guān)于java中優(yōu)化大量if...else...方法的相關(guān)資料,需要的朋友可以參考下2023-03-03

