您好,登錄后才能下訂單哦!
這篇“Java過濾器Filter如何使用教程”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Java過濾器Filter如何使用教程”文章吧。
過濾器Filter
用于攔截請求、過濾響應(yīng)
在不使用過濾器時,瀏覽器向服務(wù)器發(fā)送請求后,服務(wù)器將會直接去獲取資源并響應(yīng)給瀏覽器
添加Filter后,瀏覽器向服務(wù)器發(fā)送請求,請求在到達服務(wù)器之間會先經(jīng)過Filter,在Filter進行一系列判斷后滿足條件才可以被允許通過過濾到達服務(wù)器. 而服務(wù)器的響應(yīng)在抵達瀏覽器之前同樣會先經(jīng)過Filter之后才會到瀏覽器
Filter使用:
導包:javax.servlet.Filter
Filter是一個接口,符合JavaEE規(guī)范
Filter接口的實現(xiàn)類被稱作是一個過濾器,實現(xiàn)類需要重寫Filter中的抽象方法
Filter中有三個方法如下
// init--> 初始化方法 default public void init(FilterConfig filterConfig) throws ServletException {} // doFilter--> 過濾器實體方法 public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain)throws IOException, ServletException; // destroy --> 銷毀過濾器的方法 default public void destroy() {}
init:在Web工程啟動時就會調(diào)用進行初始化
doFilter:三個參數(shù): request請求和response響應(yīng) chain鏈
FilterChain:過濾器鏈,當前過濾器過濾通過后會將請求或響應(yīng)交給下一個過濾器執(zhí)行,可以理解為當前過濾器允許該請求或響應(yīng)通過
// 過濾器放行的固定寫法 chain.doFilter(request, response);
destory:銷毀該過濾器
配置Filter:
// 注解 @WebFilter(urlPatterns = {"/doFilter"}) // Web.xml配置 與配置Servlet方法相同 <filter> <filter-name>filterTest</filter-name> <filter-class>com.filter.TestFilter</filter-class> </filter> <filter-mapping> <filter-name>filterTest</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
使用實例:
向web界面輸出文字,通過過濾器進行編碼,不通過過濾器將會打印亂碼
// 過濾器 @WebFilter(urlPatterns = {"/doFilter"}) public class Filter01 implements Filter { // 初始化方法 public void init(FilterConfig filterConfig) throws ServletException { System.out.println("Filter初始化完成"); } // 過濾器主體 public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { request.setCharacterEncoding("UTF-8"); response.setCharacterEncoding("UTF-8"); response.setContentType("text/html;charset:utf-8"); // 允許通過過濾器 chain.doFilter(request, response); } // 銷毀方法 public void destroy() { System.out.println("Filter被銷毀"); } } // Servlet @WebServlet(urlPatterns = {"/doFilter","/doNotFilter"}) public class Demo01 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.getWriter().write("<h2>你好,鄭州</h2>"); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } }
上述代碼所示:當通過映射路徑/doNotFilter將會打印出中文亂碼,反之通過/doFilter則會設(shè)置好響應(yīng)的中文編碼正常輸出
以上就是關(guān)于“Java過濾器Filter如何使用教程”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。