使用spring攔截器實現(xiàn)日志管理實例
使用HandlerInterceptor攔截器,可以攔截請求,實現(xiàn)通用的日志管理操作
一、添加攔截器類
在"src/main/java"代碼文件夾的"org.xs.demo1"的包下新建"LogInterceptor.java"類:
package org.xs.demo1;
import java.text.SimpleDateFormat;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.core.NamedThreadLocal;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
/**
* 日志攔截器
* @author ThinkGem
*/
public class LogInterceptor implements HandlerInterceptor {
private final Logger log = LoggerFactory.getLogger(getClass().getName());
private static final ThreadLocal<Long> startTimeThreadLocal = new NamedThreadLocal<Long>("ThreadLocal StartTime");
/**
* 預(yù)處理
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
long beginTime = System.currentTimeMillis(); //開始時間
startTimeThreadLocal.set(beginTime); //線程綁定變量(該數(shù)據(jù)只有當(dāng)前請求的線程可見)
log.info("開始計時: {}", new SimpleDateFormat("hh:mm:ss.SSS").format(beginTime));
return true;
}
/**
* 返回處理
*/
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
if (modelAndView != null){
log.info("ViewName: " + modelAndView.getViewName());
}
}
/**
* 后處理
*/
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
// 保存日志
//LogUtils.saveLog(request, handler, ex, null);
// 輸出日志信息
log.info("訪問地址:" + request.getRequestURI() + ",執(zhí)行方式:" + request.getMethod());
long beginTime = startTimeThreadLocal.get(); //得到線程綁定的局部變量(開始時間)
long endTime = System.currentTimeMillis(); //結(jié)束時間
log.info("計時結(jié)束:{}", new SimpleDateFormat("hh:mm:ss.SSS").format(endTime));
}
}
二、修改配置文件
修改spring-mvc.xml件,加入:
<!-- 攔截器配置 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean class="org.xs.demo1.LogInterceptor" />
</mvc:interceptor>
</mvc:interceptors>
三、運行測試
訪問"http://localhost:8080/demo1/hello/list2"地址

可以看到攔截器中輸出的日志信息了
實例代碼地址:spring-HandlerInterceptor_jb51.rar
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot+WebSocket實現(xiàn)即時通訊功能(Spring方式)
今天給大家分享一個SpringBoot+WebSocket實現(xiàn)即時通訊功能(Spring方式),WebSocket是一種在單個TCP連接上進(jìn)行全雙工通信的協(xié)議,文章通過代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10
Spring?Boot?實現(xiàn)字段唯一校驗功能(實例代碼)
這篇文章主要介紹了Spring?Boot?實現(xiàn)字段唯一校驗,實現(xiàn)代碼很簡單,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08
RabbitMq報錯reply-code=406 reply-text=PRECONDITION_FAILED
這篇文章主要為大家介紹了RabbitMq報錯reply-code=406 reply-text=PRECONDITION_FAILED分析解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
idea中文件被Mark as Plain Text后恢復(fù)方式
在IntelliJ IDEA中,如果錯誤地將文件標(biāo)記為純文本(Mark as Plain Text),可以通過在項目目錄中右鍵點擊文件并選擇“Mark as”來恢復(fù)原文件類型2024-11-11

