91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

白银市| 元阳县| 吕梁市| 张家口市| 竹溪县| 仪陇县| 长泰县| 远安县| 张掖市| 滕州市| 万宁市| 宣化县| 西华县| 资兴市| 甘孜县| 乌鲁木齐市| 垦利县| 余庆县| 沙雅县| 西城区| 互助| 寿阳县| 镇远县| 林周县| 车致| 镇巴县| 綦江县| 秭归县| 临江市| 厦门市| 阳原县| 德钦县| 武川县| 扎囊县| 宁波市| 手游| 平潭县| 略阳县| 黑河市| 天等县| 太保市|