您好,登錄后才能下訂單哦!
這篇文章主要講解了“Servlet過濾器概念特點(diǎn)有哪些”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Servlet過濾器概念特點(diǎn)有哪些”吧!
一、Servlet過濾器的概念:
◆Servlet過濾器是在Java Servlet規(guī)范2.3中定義的,它能夠?qū)ervlet容器的請(qǐng)求和響應(yīng)對(duì)象進(jìn)行檢查和修改?!?/p>
◆Servlet過濾器本身并不產(chǎn)生請(qǐng)求和響應(yīng)對(duì)象,它只能提供過濾作用。Servlet過期能夠在Servlet被調(diào)用之前檢查Request對(duì)象,修改Request Header和Request內(nèi)容;在Servlet被調(diào)用之后檢查Response對(duì)象,修改Response Header和Response內(nèi)容。
Servlet過期負(fù)責(zé)過濾的Web組件可以是Servlet、JSP或者HTML文件?!?/p>
二、Servlet過濾器的特點(diǎn):
◆Servlet過濾器可以檢查和修改ServletRequest和ServletResponse對(duì)象
◆Servlet過濾器可以被指定和特定的URL關(guān)聯(lián),只有當(dāng)客戶請(qǐng)求訪問該URL時(shí),才會(huì)觸發(fā)過濾器
◆Servlet過濾器可以被串聯(lián)在一起,形成管道效應(yīng),協(xié)同修改請(qǐng)求和響應(yīng)對(duì)象
三、Servlet過濾器的作用:
◆查詢請(qǐng)求并作出相應(yīng)的行動(dòng)。
◆阻塞請(qǐng)求-響應(yīng)對(duì),使其不能進(jìn)一步傳遞。
◆修改請(qǐng)求的頭部和數(shù)據(jù)。用戶可以提供自定義的請(qǐng)求。
◆修改響應(yīng)的頭部和數(shù)據(jù)。用戶可以通過提供定制的響應(yīng)版本實(shí)現(xiàn)。
◆與外部資源進(jìn)行交互。
四、Servlet過濾器的適用場(chǎng)合:
◆認(rèn)證過濾
◆登錄和審核過濾
◆圖像轉(zhuǎn)換過濾
◆數(shù)據(jù)壓縮過濾
◆加密過濾
◆令牌過濾
◆資源訪問觸發(fā)事件過濾
◆XSL/T過濾
◆Mime-type過濾
五、Servlet過濾器接口的構(gòu)成:
所有的Servlet過濾器類都必須實(shí)現(xiàn)javax.servlet.Filter接口。這個(gè)接口含有3個(gè)過濾器類必須實(shí)現(xiàn)的方法:
◆init(FilterConfig):
這是Servlet過濾器的初始化方法,Servlet容器創(chuàng)建Servlet過濾器實(shí)例后將調(diào)用這個(gè)方法。在這個(gè)方法中可以讀取web.xml文件中Servlet過濾器的初始化參數(shù)
◆doFilter(ServletRequest,ServletResponse,FilterChain):
這個(gè)方法完成實(shí)際的過濾操作,當(dāng)客戶請(qǐng)求訪問于過濾器關(guān)聯(lián)的URL時(shí),Servlet容器將先調(diào)用過濾器的doFilter方法。FilterChain參數(shù)用于訪問后續(xù)過濾器
◆destroy():
Servlet容器在銷毀過濾器實(shí)例前調(diào)用該方法,這個(gè)方法中可以釋放Servlet過濾器占用的資源
六、Servlet過濾器的創(chuàng)建步驟:
◆實(shí)現(xiàn)javax.servlet.Filter接口
◆實(shí)現(xiàn)init方法,讀取過濾器的初始化函數(shù)
◆實(shí)現(xiàn)doFilter方法,完成對(duì)請(qǐng)求或過濾的響應(yīng)
◆調(diào)用FilterChain接口對(duì)象的doFilter方法,向后續(xù)的過濾器傳遞請(qǐng)求或響應(yīng)
◆銷毀過濾器
七、Servlet過濾器對(duì)請(qǐng)求的過濾:
◆Servlet容器創(chuàng)建一個(gè)過濾器實(shí)例
◆過濾器實(shí)例調(diào)用init方法,讀取過濾器的初始化參數(shù)
◆過濾器實(shí)例調(diào)用doFilter方法,根據(jù)初始化參數(shù)的值判斷該請(qǐng)求是否合法
◆如果該請(qǐng)求不合法則阻塞該請(qǐng)求
◆如果該請(qǐng)求合法則調(diào)用chain.doFilter方法將該請(qǐng)求向后續(xù)傳遞
八、Servlet過濾器對(duì)響應(yīng)的過濾:
◆過濾器截獲客戶端的請(qǐng)求
◆重新封裝ServletResponse,在封裝后的ServletResponse中提供用戶自定義的輸出流
◆將請(qǐng)求向后續(xù)傳遞
◆Web組件產(chǎn)生響應(yīng)
◆從封裝后的ServletResponse中獲取用戶自定義的輸出流
◆將響應(yīng)內(nèi)容通過用戶自定義的輸出流寫入到緩沖流中
◆在緩沖流中修改響應(yīng)的內(nèi)容后清空緩沖流,輸出響應(yīng)內(nèi)容
九、Servlet過濾器的發(fā)布:
◆發(fā)布Servlet過濾器時(shí),必須在web.xml文件中加入﹤filter﹥?cè)睾桐俧ilter-mapping﹥?cè)亍?/p>
◆filter元素用來(lái)定義一個(gè)過濾器:
//屬性 含義 filter-name 指定過濾器的名字 filter-class 指定過濾器的類名 init-param 為過濾器實(shí)例提供初始化參數(shù),可以有多個(gè)
◆filter-mapping元素用于將過濾器和URL關(guān)聯(lián):
//屬性 含義 filter-name 指定過濾器的名字 url-pattern 指定和過濾器關(guān)聯(lián)的URL,為”/*”表示所有URL
十一、Servlet過濾器使用的注意事項(xiàng)
◆由于Filter、FilterConfig、FilterChain都是位于javax.servlet包下,并非HTTP包所特有的,所以其中所用到的請(qǐng)求、響應(yīng)對(duì)象ServletRequest、ServletResponse在使用前都必須先轉(zhuǎn)換成HttpServletRequest、HttpServletResponse再進(jìn)行下一步操作。
◆在web.xml中配置Servlet和Servlet過濾器,應(yīng)該先聲明過濾器元素,再聲明Servlet元素
◆如果要在Servlet中觀察過濾器生成的日志,應(yīng)該確保在server.xml的localhost對(duì)應(yīng)的﹤host﹥?cè)刂信渲萌缦漏俵ogger﹥?cè)兀?/p>
﹤Logger className = “org.apache.catalina.logger.FileLogger” directory = “l(fā)ogs”prefix = “l(fā)ocalhost_log.”suffix=”.txt” timestamp = “true”/﹥
感謝各位的閱讀,以上就是“Servlet過濾器概念特點(diǎn)有哪些”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)Servlet過濾器概念特點(diǎn)有哪些這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。