一、在spring的應用中我們存在兩種過濾的用法,一種是攔截器、另外一種當然是過濾器。我們這里介紹過濾器在springboot的用法,在springmvc中的用法基本上一樣,只是配置上面有點區別。
二、filter功能,它使用戶可以改變一個 request和修改一個response. Filter 不是一個servlet,它不能產生一個response,它能夠在一個request到達servlet之前預處理request,也可以在離開 servlet時處理response.換種說法,filter其實是一個”servlet chaining”(servlet 鏈).
一個Filter包括:
1)、在servlet被調用之前截獲;
2)、在servlet被調用之前檢查servlet request;
3)、根據需要修改request頭和request數據;
4)、根據需要修改response頭和response數據;
5)、在servlet被調用之后截獲.
1、Filter的應用場景
通過對filter過濾器的了解,可以得知在以下三種情況下可以做些處理:
1> 通過控制對chain.doFilter的方法的調用,來決定是否需要訪問目標資源。
比如,可以在用戶權限驗證等等。判斷用戶是否有訪問某些資源的權限,有權限放行,沒權限不執行chain.doFilter方法。
2> 通過在調用chain.doFilter方法之前,做些處理來達到某些目的。
比如,解決中文亂碼的問題等等。可以在doFilter方法前,執行設置請求編碼與響應的編碼。甚至可以對request接口進行封裝裝飾來處理get請求方式的中文亂碼問題(重寫相應的request.getParameter方法)。
3> 通過在調用chain.doFilter方法之后,做些處理來達到某些目的。
比如對整個web網站進行壓縮。在調用chain.doFilter方法之前用類A對response對象進行封裝裝飾,重寫getOutputStream和重寫getWriter方法。在類A內部中,將輸出內容緩存進ByteArrayOutputStream流中,然后在chain.doFilter方法執行后,獲取類A中ByteArrayOutputStream流緩存數據,用GZIPOutputStream流進行壓縮下。
2、Filter實現攔截的原理
Filter接口中有一個doFilter方法,當開發人員編寫好Filter類實現doFilter方法,并配置對哪個web資源進行攔截后,WEB服務器每次在調用web資源的service方法之前(服務器內部對資源的訪問機制決定的),都會先調用一下filter的doFilter方法。
3、過濾規則
1
2
3
4
5
6
7
8
|
//過濾應用程序中所有資源,當前應用程序根下的所有文件包括多級子目錄下的所有文件,注意這里*前有“/” registration.addUrlPatterns( "/*" ); //過濾指定的類型文件資源, 當前應用程序根目錄下的所有html文件,注意:*.html前沒有“/”,否則錯誤 registration.addUrlPatterns( ".html" ); //過濾指定的目錄下的所有文件,當前應用程序根目錄下的folder_name子目錄(可以是多級子目錄)下所有文件 registration.addUrlPatterns( "/folder_name/*" ); //過濾指定文件 registration.addUrlPatterns( "/index.html" ); |
三、應用
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
@Component @ServletComponentScan @WebFilter (urlPatterns = "/login/*" ,filterName = "loginFilter" ) public class LoginFilter implements Filter{ @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { } @Override public void destroy() { } } |
四、解釋:
1、@Component 這個注解的目的是將LoginFilter交給容器來處理。也就是讓LoginFilter起作用
2、@ServletComponentScan 這個使用來掃描@WebFilter 的讓@WebFilter起作用。當然對于servlet線管注解也是可以的。這個@ServletComponentScan最好卸載Apllication這個上面,通用配置。我這里因為只有一個Filter所以沒有寫在Application上面。
3、@WebFilter 這個用處顯而易見,針對于什么鏈接做過濾,filter的名稱是為什么。
五、簡單介紹一下springmvc中的Filter的用法
1、寫的方法還是一樣的都是繼承Filter,來實現3個方法處理
2、丟入容器:這個需要配置在web.xml里面
1
2
3
4
5
6
7
8
|
< filter > < filter-name >loginFilter</ filter-name > < filter-class >com.troy.boot.filter.LoginFilter</ filter-class > </ filter > < filter-mapping > < filter-name >loginFilter</ filter-name > < url-pattern >/*</ url-pattern > </ filter-mapping > |
3、具體的用法可以自己研究。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://www.cnblogs.com/ll409546297/p/7422833.html