springboot中filter的用法詳解
一、在spring的應用中我們存在兩種過濾的用法,一種是攔截器、另外一種當然是過濾器。我們這里介紹過濾器在springboot的用法,在springmvc中的用法基本上一樣,只是配置上面有點區(qū)別。
二、filter功能,它使用戶可以改變一個 request和修改一個response. Filter 不是一個servlet,它不能產(chǎn)生一個response,它能夠在一個request到達servlet之前預處理request,也可以在離開 servlet時處理response.換種說法,filter其實是一個”servlet chaining”(servlet 鏈).
一個Filter包括:
1)、在servlet被調(diào)用之前截獲;
2)、在servlet被調(diào)用之前檢查servlet request;
3)、根據(jù)需要修改request頭和request數(shù)據(jù);
4)、根據(jù)需要修改response頭和response數(shù)據(jù);
5)、在servlet被調(diào)用之后截獲.
1、Filter的應用場景
通過對filter過濾器的了解,可以得知在以下三種情況下可以做些處理:
1> 通過控制對chain.doFilter的方法的調(diào)用,來決定是否需要訪問目標資源。
比如,可以在用戶權限驗證等等。判斷用戶是否有訪問某些資源的權限,有權限放行,沒權限不執(zhí)行chain.doFilter方法。
2> 通過在調(diào)用chain.doFilter方法之前,做些處理來達到某些目的。
比如,解決中文亂碼的問題等等。可以在doFilter方法前,執(zhí)行設置請求編碼與響應的編碼。甚至可以對request接口進行封裝裝飾來處理get請求方式的中文亂碼問題(重寫相應的request.getParameter方法)。
3> 通過在調(diào)用chain.doFilter方法之后,做些處理來達到某些目的。
比如對整個web網(wǎng)站進行壓縮。在調(diào)用chain.doFilter方法之前用類A對response對象進行封裝裝飾,重寫getOutputStream和重寫getWriter方法。在類A內(nèi)部中,將輸出內(nèi)容緩存進ByteArrayOutputStream流中,然后在chain.doFilter方法執(zhí)行后,獲取類A中ByteArrayOutputStream流緩存數(shù)據(jù),用GZIPOutputStream流進行壓縮下。
2、Filter實現(xiàn)攔截的原理
Filter接口中有一個doFilter方法,當開發(fā)人員編寫好Filter類實現(xiàn)doFilter方法,并配置對哪個web資源進行攔截后,WEB服務器每次在調(diào)用web資源的service方法之前(服務器內(nèi)部對資源的訪問機制決定的),都會先調(diào)用一下filter的doFilter方法。
3、過濾規(guī)則
//過濾應用程序中所有資源,當前應用程序根下的所有文件包括多級子目錄下的所有文件,注意這里*前有“/”
registration.addUrlPatterns("/*");
//過濾指定的類型文件資源, 當前應用程序根目錄下的所有html文件,注意:*.html前沒有“/”,否則錯誤
registration.addUrlPatterns(".html");
//過濾指定的目錄下的所有文件,當前應用程序根目錄下的folder_name子目錄(可以是多級子目錄)下所有文件
registration.addUrlPatterns("/folder_name/*");
//過濾指定文件
registration.addUrlPatterns("/index.html");
三、應用
@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,來實現(xiàn)3個方法處理
2、丟入容器:這個需要配置在web.xml里面
<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、具體的用法可以自己研究。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Java方法調(diào)用解析靜態(tài)分派動態(tài)分派執(zhí)行過程
這篇文章主要為大家介紹了Java方法調(diào)用解析靜態(tài)分派動態(tài)分派執(zhí)行過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06
Java如何獲取List<String>中的String詳解
工作了這么長時間了,一直沒有記錄的習慣,以至于導致我即便是查過的東西總會忘記,下面這篇文章主要給大家介紹了關于Java如何獲取List<String>中String的相關資料,需要的朋友可以參考下2022-02-02
SpringBoot整合SpringSecurity實現(xiàn)權限控制之實現(xiàn)多標簽頁
這篇文章主要介紹了SpringBoot整合SpringSecurity實現(xiàn)權限控制之實現(xiàn)多標簽頁,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-11-11
JAVA中重寫(Override)與重載(Overload)的相關示例
這篇文章主要給大家介紹了關于JAVA中重寫(Override)與重載(Overload)的相關示例,重寫(override)和重載(overload)是兩種不同的方法重用技術,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-10-10

