欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中使用Filter過濾器的方法

 更新時間:2021年06月28日 11:16:43   作者:紅旗下的小兵  
Filter過濾器是javaWeb層面的,它跟Servlet類似,每次前端請求,首先進入的是過濾器,我們必須實現(xiàn)Filter接口,重寫三個方法,才能使用Filter過濾器,需要的朋友可以參考下

Filter過濾器

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

(1) ServletRequest servletRequest 

請求reqeust;

(2)ServletResponse servletResponse 

響應response;

(3)FilterChain filterChain

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

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

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

package com.lxc.springboot.filter;
 
 
/**
 * 這個過濾器其實是給容器(tomcat)使用的
 *  public void doFilter(){} 方法參數(shù):
 *
 * ServletRequest servletRequest : 請求reqeust
 * ServletResponse servletResponse : 響應response
 * FilterChain filterChain : filterChain.doFilter() 可以使用多個過濾器,繼續(xù)調用下一個過濾器
 *
 * 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位 時間戳(毫秒)
        // 繼續(xù)往后執(zhí)行,是否有別的過濾器,沒有 -> 進入應用,執(zhí)行邏輯
        filterChain.doFilter(servletRequest, servletResponse);
        LOG.info(" --------- FilterLog 結束,耗時: {} ms --------- ", System.currentTimeMillis() - startTime);
    }
 
    // web服務器關閉時,F(xiàn)ilter會銷毀
    @Override
    public void destroy() {
        Filter.super.destroy();
    }
}

 輸出如下:

到此這篇關于Java中使用Filter過濾器的方法的文章就介紹到這了,更多相關Filter過濾器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • SpringBoot項目啟動過程動態(tài)修改接口請求路徑的解決方案

    SpringBoot項目啟動過程動態(tài)修改接口請求路徑的解決方案

    在SpringBoot服務整合過程中,遇到了多個服務中相同RequestMapping路徑導致的啟動問題,解決方案是通過修改RequestMappingHandlerMapping類的getMappingForMethod方法,本文給大家介紹SpringBoot修改接口請求路徑的解決方案,感興趣的朋友一起看看吧
    2024-09-09
  • 淺談Java并發(fā)中ReentrantLock鎖應該怎么用

    淺談Java并發(fā)中ReentrantLock鎖應該怎么用

    本文主要介紹了ava并發(fā)中ReentrantLock鎖的具體使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • java的接口解耦方式

    java的接口解耦方式

    這篇文章主要介紹了java的接口解耦方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • java fastdfs客戶端使用實例代碼

    java fastdfs客戶端使用實例代碼

    這篇文章主要介紹了java fastdfs客戶端使用實例代碼,簡單介紹了FastDFS的概念和架構,然后分享了實例代碼,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • springboot之自動裝配全過程

    springboot之自動裝配全過程

    這篇文章主要介紹了springboot之自動裝配全過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • mybatis-plus實現(xiàn)邏輯刪除的示例代碼

    mybatis-plus實現(xiàn)邏輯刪除的示例代碼

    本文主要介紹了mybatis-plus實現(xiàn)邏輯刪除的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • 不到十行實現(xiàn)javaCV圖片OCR文字識別

    不到十行實現(xiàn)javaCV圖片OCR文字識別

    識別圖片中的文字,會省很多時間,本文介紹了javaCV圖片OCR文字識別,需要的朋友們下面隨著小編來一起學習學習吧
    2021-05-05
  • MyBatis批量更新(update foreach)報錯問題

    MyBatis批量更新(update foreach)報錯問題

    這篇文章主要介紹了MyBatis批量更新(update foreach)報錯問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • idea查看properties中文變成unicode碼的解決方案

    idea查看properties中文變成unicode碼的解決方案

    這篇文章主要介紹了idea查看properties中文變成unicode碼的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • SpringBoot中驗證用戶上傳的圖片資源的方法

    SpringBoot中驗證用戶上傳的圖片資源的方法

    這篇文章主要介紹了在SpringBoot中驗證用戶上傳的圖片資源,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09

最新評論