使用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");
/**
* 預處理
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
long beginTime = System.currentTimeMillis(); //開始時間
startTimeThreadLocal.set(beginTime); //線程綁定變量(該數(shù)據只有當前請求的線程可見)
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(); //結束時間
log.info("計時結束:{}", 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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Spring實戰(zhàn)之協(xié)調作用域不同步的Bean操作示例
這篇文章主要介紹了Spring實戰(zhàn)之協(xié)調作用域不同步的Bean操作,結合實例形式分析了Spring協(xié)調作用域不同步的Bean相關配置及使用技巧,需要的朋友可以參考下2019-11-11
Java中關于String StringBuffer StringBuilder特性深度解析
這篇文章主要介紹了Java中關于String StringBuffer StringBuilder特性深度解析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09
java利用JEXL實現(xiàn)動態(tài)表達式編譯
這篇文章主要介紹了java利用JEXL實現(xiàn)動態(tài)表達式編譯,系統(tǒng)要獲取多個數(shù)據源的數(shù)據,并進行處理,最后輸出多個字段。字段的計算規(guī)則一般是簡單的取值最多加一點條件判斷,下面是具體的實現(xiàn)方法2021-04-04

