Java中使用Filter過濾器的方法
Filter過濾器
著重記錄下 public void doFilter(){} 方法參數(shù):
(1) ServletRequest servletRequest
請(qǐng)求reqeust;
(2)ServletResponse servletResponse
響應(yīng)response;
(3)FilterChain filterChain
參數(shù) filterChain,有一個(gè)doFilter() 方法,調(diào)用這個(gè)方法,可以使程序繼續(xù)往下走,執(zhí)行后續(xù)代碼,如果有多個(gè)過濾器,它會(huì)繼續(xù)執(zhí)行下一個(gè)過濾器邏輯(開發(fā)中會(huì)出現(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 : 請(qǐng)求reqeust * ServletResponse servletResponse : 響應(yīng)response * FilterChain filterChain : filterChain.doFilter() 可以使用多個(gè)過濾器,繼續(xù)調(diào)用下一個(gè)過濾器 * * IDEA: 格式化代碼 -> ctrl + alt + l * 添加 @Component 注解, spring會(huì)掃描這個(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 { // 使用指定類 - 初始化日志對(duì)象 private static final Logger LOG = LoggerFactory.getLogger(FilterLog.class); // 初始化方法 @Override public void init(FilterConfig filterConfig) throws ServletException { Filter.super.init(filterConfig); } /** * 下邊就是一個(gè)servlet,servlet - 就是我們的請(qǐng)求、響應(yīng),所以我們會(huì)拿到 request 和 response * * @param servletRequest * @param servletResponse * @param filterChain */ @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { /** * request 可以拿到所有的請(qǐng)求信息?。?! */ HttpServletRequest request = (HttpServletRequest) servletRequest; LOG.info("【全局過濾器】"); LOG.info("--------- FilterLog日志開始 --------- "); LOG.info("- 請(qǐng)求地址: {}, 方法: {}", 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會(huì)銷毀 @Override public void destroy() { Filter.super.destroy(); } }
輸出如下:
到此這篇關(guān)于Java中使用Filter過濾器的方法的文章就介紹到這了,更多相關(guān)Filter過濾器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot項(xiàng)目啟動(dòng)過程動(dòng)態(tài)修改接口請(qǐng)求路徑的解決方案
在SpringBoot服務(wù)整合過程中,遇到了多個(gè)服務(wù)中相同RequestMapping路徑導(dǎo)致的啟動(dòng)問題,解決方案是通過修改RequestMappingHandlerMapping類的getMappingForMethod方法,本文給大家介紹SpringBoot修改接口請(qǐng)求路徑的解決方案,感興趣的朋友一起看看吧2024-09-09淺談Java并發(fā)中ReentrantLock鎖應(yīng)該怎么用
本文主要介紹了ava并發(fā)中ReentrantLock鎖的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11mybatis-plus實(shí)現(xiàn)邏輯刪除的示例代碼
本文主要介紹了mybatis-plus實(shí)現(xiàn)邏輯刪除的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05不到十行實(shí)現(xiàn)javaCV圖片OCR文字識(shí)別
識(shí)別圖片中的文字,會(huì)省很多時(shí)間,本文介紹了javaCV圖片OCR文字識(shí)別,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05MyBatis批量更新(update foreach)報(bào)錯(cuò)問題
這篇文章主要介紹了MyBatis批量更新(update foreach)報(bào)錯(cuò)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08idea查看properties中文變成unicode碼的解決方案
這篇文章主要介紹了idea查看properties中文變成unicode碼的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06SpringBoot中驗(yàn)證用戶上傳的圖片資源的方法
這篇文章主要介紹了在SpringBoot中驗(yàn)證用戶上傳的圖片資源,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09