程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> 使用spring攔截器實現日志管理實例

使用spring攔截器實現日志管理實例

編輯:關於JAVA

使用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:原文翻譯及解析]
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved