中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

使用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

蓝田县| 清镇市| 尼木县| 舞阳县| 德钦县| 德格县| 宁德市| 青阳县| 资中县| 大兴区| 常宁市| 高雄县| 淮阳县| 夏河县| 秦皇岛市| 巩义市| 大竹县| 绍兴县| 岳阳县| 理塘县| 柞水县| 合水县| 内江市| 竹溪县| 菏泽市| 兴城市| 甘德县| 仙桃市| 巴彦淖尔市| 合作市| 民权县| 临夏市| 建宁县| 永平县| 衢州市| 壤塘县| 耿马| 延津县| 韶关市| 三江| 武乡县|