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過濾器的方法的文章就介紹到這瞭,更多相關Filter過濾器內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- SpringBoot實現過濾器攔截器的耗時對比
- 詳解JavaWeb中的過濾器Filter
- CorsFilter 過濾器解決跨域的處理
- java web項目Session獲取不到問題及解決
- Java中過濾器 (Filter) 和 攔截器 (Interceptor)的使用