什麼是過濾器 過濾器就是 Servlet 的高級特性之一, 就是一個具有 攔截/過濾 功能的一個東西,在生活中過濾器可以是香煙濾嘴,濾紙,凈水器,空氣凈化器等,在 Web 中僅僅是一個 實現了 Filter 介面的 Java 類 而已。 特點:雙向,攔截請求,攔截響應 作用: 過濾器可以對 所有的請 ...
什麼是過濾器
過濾器就是 Servlet 的高級特性之一,就是一個具有攔截/過濾功能的一個東西,在生活中過濾器可以是香煙濾嘴,濾紙,凈水器,空氣凈化器等,在 Web 中僅僅是一個實現了 Filter 介面的 Java 類而已。
特點:雙向,攔截請求,攔截響應
作用:
過濾器可以對所有的請求或者響應做攔截操作
為什麼在 Web 開發中需要用到過濾器?
- 問題:為什麼非得使用過濾器,我直接在 Servlet 中作判斷不行嗎?
- 開發遵循的原則:
1.DRY原則(Don't Reeat Yourself,不要重覆你自己):重覆,意味著維護的成本很高。
2.責任分離原則:誰擅長什麼功能就做什麼功能,Servlet 擅長的是邏輯而不是處理請求
舉一個實際的例子:(處理 POST 請求中文編碼的問題)
- Web 中過濾器的作用:
1.可以在請求資源之前設置請求的編碼
2.可以進行登錄校驗
3.可以進行請求參數的內容的過濾
4.數據壓縮 / 數據加密 / 數據格式的轉換
5.可以設置瀏覽器相關的數據
Filter 的開發和使用
對應於 Servlet 的開發步驟:
- 定義一個類,實現 Filter 介面
- 在 doFilter() 方法中對請求和響應進行過濾
在 web.xml 文件中進行 Filter 的配置(告訴伺服器來管理當前的 Filter)
<!-- web.xml --> <filter> <filter-name>filter的名稱</filter-name> <filter-class>filter類的全限定名</filter-class> </filter> <filter-mapping> <filter-name>指定對哪一個filter做的映射</filter-name> <url-pattern>指定對哪些資源進行過濾</url-pattern> </filter-mapping>
- 註意:此時
<url-pattern>
表示對哪些資源做過濾/攔截。例如: /hello.jsp
當前 Filter 就僅僅只對 hello.jsp 資源做攔截./index
當前 Filter 就僅僅只對 /index 資源做攔截./*
當前 Filter 就對所有資源做攔截.訪問任意的資源,都會先進入該過濾器器./system/*
當前 Filter 就對以/system/
打頭的資源做攔截.
如/system
,/system/a
,/system/a/b/c
,/systema
Filter 映射細節
- 在啟動伺服器的時候,就創建了 Filter 對象並執行了初始化方法 init()。Filter 先於 Servlet 存在於服務端
- 在應用中允許存在多個 Filter ,到底哪一個 Filter 先執行哪一個後執行,這取決於在
web.xml
中定義的先後次序 (如果使用註解配置,則 Filter 的執行順序由 Filter 的類名的字母的順序來決定,如 AFilter 和 BFilter,則先執行 AFilter) - 一個 Filter 可以配置多個
<url-pattern>
也可以對指定的 Servlet 做過濾(註解通過servletNames
指定,配置由<servlet-name>
指定) - 預設情況下,Filter 只對新的請求做攔截,如果是請求轉發,則不會過濾。
<dispatcher>
配置項指定了 Filter 的過濾時間:REQUEST
:只對請求做過濾,預設選項,如果有該配置項則必須顯式寫明FORWARD
:只對請求轉發(forword)方式做過濾ERROR
:只對跳轉到全局的錯誤頁面做過濾INCLUDE
:只對請求包含(include)方式做過濾- 對應的註解屬性為:
dispatcherTypes
過濾器實例
監聽器
作用:
1.監聽 web 應用的創建和銷毀
2.attribute發生的變化。web 應用:即ServletContext對象(jsp的隱式對象application)
除了對web應用的監聽外,還能監聽session和request的生命周期,以及他們的attribute發生的變化。
瞭解詳情戳這裡
歡迎轉載,轉載請註明出處!
@我沒有三顆心臟
CSDN博客:http://blog.csdn.net/qq939419061
簡書:http://www.jianshu.com/u/a40d61a49221