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

溫馨提示×

溫馨提示×

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

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

Java中如何使用Filter過濾器

發布時間:2021-06-28 14:18:45 來源:億速云 閱讀:178 作者:小新 欄目:開發技術

這篇文章主要介紹了Java中如何使用Filter過濾器,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Filter過濾器

著重記錄下 public void doFilter(){} 方法參數:

(1) ServletRequest servletRequest 

請求reqeust;

(2)ServletResponse servletResponse 

響應response;

(3)FilterChain filterChain

參數 filterChain,有一個doFilter() 方法,調用這個方法,可以使程序繼續往下走,執行后續代碼,如果有多個過濾器,它會繼續執行下一個過濾器邏輯(開發中會出現多個過濾器情況)。

例子(下邊例子是在springboot項目中的)

使用過濾器,日志輸出接口的響應時間
filter -> FilterLog.java

package com.lxc.springboot.filter;
 
 
/**
 * 這個過濾器其實是給容器(tomcat)使用的
 *  public void doFilter(){} 方法參數:
 *
 * ServletRequest servletRequest : 請求reqeust
 * ServletResponse servletResponse : 響應response
 * FilterChain filterChain : filterChain.doFilter() 可以使用多個過濾器,繼續調用下一個過濾器
 *
 * IDEA: 格式化代碼 -> ctrl + alt + l
 * 添加 @Component 注解, spring會掃描這個類
 */
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
 
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
 
@Component
public class FilterLog implements Filter {
    // 使用指定類 - 初始化日志對象
    private static final Logger LOG = LoggerFactory.getLogger(FilterLog.class);
 
    // 初始化方法
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        Filter.super.init(filterConfig);
    }
 
    /**
     * 下邊就是一個servlet,servlet - 就是我們的請求、響應,所以我們會拿到 request 和 response
     *
     * @param servletRequest
     * @param servletResponse
     * @param filterChain
     */
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        /**
         * request 可以拿到所有的請求信息!!!
         */
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        LOG.info("【全局過濾器】");
        LOG.info("--------- FilterLog日志開始 --------- ");
        LOG.info("- 請求地址: {}, 方法: {}", request.getRequestURL().toString(), request.getMethod());
        LOG.info("- 遠程地址: {}, 域名: {}, 端口: {}", request.getRemoteAddr(), request.getRemoteHost(), request.getRemotePort());
        long startTime = System.currentTimeMillis(); // 13位 時間戳(毫秒)
        // 繼續往后執行,是否有別的過濾器,沒有 -> 進入應用,執行邏輯
        filterChain.doFilter(servletRequest, servletResponse);
        LOG.info(" --------- FilterLog 結束,耗時: {} ms --------- ", System.currentTimeMillis() - startTime);
    }
 
    // web服務器關閉時,Filter會銷毀
    @Override
    public void destroy() {
        Filter.super.destroy();
    }
}

 輸出如下:

Java中如何使用Filter過濾器

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Java中如何使用Filter過濾器”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

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

AI

台山市| 沭阳县| 青海省| 昌黎县| 泰和县| 当雄县| 浦城县| 阿坝县| 临海市| 自治县| 长宁县| 麻江县| 安塞县| 光泽县| 泉州市| 黄山市| 济阳县| 连城县| 舞钢市| 吉安县| 上蔡县| 湘潭县| 上饶市| 灵璧县| 读书| 乌鲁木齐县| 庄河市| 普兰店市| 正定县| 额敏县| 湛江市| 迁西县| 东兰县| 如皋市| 宣汉县| 镇赉县| 石林| 古交市| 荥经县| 泽库县| 浦城县|