亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-10-02 13:06:22 來源:腳本之家 閱讀:141 作者:ctxsdhy 欄目:編程語言

使用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攔截器實現日志管理實例

可以看到攔截器中輸出的日志信息了

實例代碼地址:spring-HandlerInterceptor_jb51.rar

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东安县| 安丘市| 武宁县| 桑日县| 宁武县| 满城县| 北辰区| 乌兰县| 米林县| 上林县| 莒南县| 江城| 千阳县| 富源县| 福泉市| 长葛市| 余姚市| 墨竹工卡县| 巴彦淖尔市| 济宁市| 东丽区| 丹江口市| 洪泽县| 藁城市| 宝兴县| 陈巴尔虎旗| 平南县| 永修县| 邻水| 呼玛县| 沅江市| 山东省| 奉节县| 玉林市| 咸丰县| 宜城市| 宝清县| 疏附县| 宜宾市| 卢氏县| 禄劝|