使用spring攔截器實現日志管理實例。本站提示廣大學習愛好者:(使用spring攔截器實現日志管理實例)文章只能為提供參考,不一定能成為您想要的結果。以下是使用spring攔截器實現日志管理實例正文
使用HandlerInterceptor攔截器,可以攔截請求,實現通用的日志管理操作
一、添加攔截器類
在"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); //線程綁定變量(該數據只有當前請求的線程可見)
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() + ",執行方式:" + 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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。
[db:作者簡介][db:原文翻譯及解析]