Java中使用Filter過濾器的方法
Filter過濾器
著重記錄下 public void doFilter(){} 方法參數(shù):
(1) ServletRequest servletRequest
請求reqeust;
(2)ServletResponse servletResponse
響應(yīng)response;
(3)FilterChain filterChain
參數(shù) filterChain,有一個(gè)doFilter() 方法,調(diào)用這個(gè)方法,可以使程序繼續(xù)往下走,執(zhí)行后續(xù)代碼,如果有多個(gè)過濾器,它會繼續(xù)執(zhí)行下一個(gè)過濾器邏輯(開發(fā)中會出現(xiàn)多個(gè)過濾器情況)。
例子(下邊例子是在springboot項(xiàng)目中的)
使用過濾器,日志輸出接口的響應(yīng)時(shí)間
filter -> FilterLog.java
package com.lxc.springboot.filter;
/**
* 這個(gè)過濾器其實(shí)是給容器(tomcat)使用的
* public void doFilter(){} 方法參數(shù):
*
* ServletRequest servletRequest : 請求reqeust
* ServletResponse servletResponse : 響應(yīng)response
* FilterChain filterChain : filterChain.doFilter() 可以使用多個(gè)過濾器,繼續(xù)調(diào)用下一個(gè)過濾器
*
* IDEA: 格式化代碼 -> ctrl + alt + l
* 添加 @Component 注解, spring會掃描這個(gè)類
*/
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);
}
/**
* 下邊就是一個(gè)servlet,servlet - 就是我們的請求、響應(yīng),所以我們會拿到 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("- 遠(yuǎn)程地址: {}, 域名: {}, 端口: {}", request.getRemoteAddr(), request.getRemoteHost(), request.getRemotePort());
long startTime = System.currentTimeMillis(); // 13位 時(shí)間戳(毫秒)
// 繼續(xù)往后執(zhí)行,是否有別的過濾器,沒有 -> 進(jìn)入應(yīng)用,執(zhí)行邏輯
filterChain.doFilter(servletRequest, servletResponse);
LOG.info(" --------- FilterLog 結(jié)束,耗時(shí): {} ms --------- ", System.currentTimeMillis() - startTime);
}
// web服務(wù)器關(guān)閉時(shí),F(xiàn)ilter會銷毀
@Override
public void destroy() {
Filter.super.destroy();
}
}
輸出如下:

到此這篇關(guān)于Java中使用Filter過濾器的方法的文章就介紹到這了,更多相關(guān)Filter過濾器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
OutOfMemoryError內(nèi)存不足和StackOverflowError堆棧溢出示例詳解
這篇文章主要為大家介紹了OutOfMemoryError內(nèi)存不足和StackOverflowError堆棧溢出示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
Java多數(shù)據(jù)源的三種實(shí)現(xiàn)方式小結(jié)
多數(shù)據(jù)源是在一個(gè)應(yīng)用程序中配置和使用多個(gè)不同的數(shù)據(jù)庫連接,本文主要介紹了Java多數(shù)據(jù)源的三種實(shí)現(xiàn)方式小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2025-03-03
Java去重排序之Comparable與Comparator的使用及說明
這篇文章主要介紹了Java去重排序之Comparable與Comparator的使用及說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
Java基于分治算法實(shí)現(xiàn)的線性時(shí)間選擇操作示例
這篇文章主要介紹了Java基于分治算法實(shí)現(xiàn)的線性時(shí)間選擇操作,涉及java排序、比較、計(jì)算等相關(guān)操作技巧,需要的朋友可以參考下2017-11-11
Java持久化框架Hibernate與Mybatis優(yōu)劣及選擇詳解
這篇文章主要介紹了Java持久化框架Hibernate與Mybatis優(yōu)劣及選擇詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
mybatis框架order by作為參數(shù)傳入時(shí)失效的解決
這篇文章主要介紹了mybatis框架order by作為參數(shù)傳入時(shí)失效的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06

