您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何進行Java過濾器doFilter里chain.doFilter()函數的理解,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
關于chain.doFilter()函數在最近的使用中不是很理解,但是考慮到他是過濾器。過濾器顧名思義就是在執行某件事情的時候開始之前。
開始進行處理的叫做過濾處理。一個方法,一個類就是充當過濾器的角色。它是在一個容器(類似于Tomcat)啟動之后,打開一網站,他就會根據配置就行過濾處理。
doFilter()方法就是過濾器的主要方法,init()方法就是在容器啟動的時候執行的。doFilter()方法中的chain.doFilter(request,response)方法剛開始還有些不怎么理解。現在有一點明白了。
doFilter(request,response)的方法就是在你打開一個頁面當滿足過濾器的條件的時候,他就會繼續執行你打開頁面時候的操作。同時如果你使用了httpservletrequest和httpservletResponse的話,獲取servletPath的值就是你要打開的文件的地址。
例子如下:
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req=(HttpServletRequest)request; HttpServletResponse resp=(HttpServletResponse)response; String servletPath= req.getServletPath(); HttpSession session=req.getSession(); String flag=(String)session.getAttribute("flag"); if(servletPath!=null&&(servletPath.equals("/03/index.jsp")||servletPath.equals("/03/login.jsp")||servletPath.equals("/loginServlet17"))){ chain.doFilter(request, response); }else{ if(flag!=null&&flag.equals("login_success")){ chain.doFilter(request, response); }else if(flag!=null&&flag.equals("login_error")){ req.setAttribute("msg", "登錄失敗,請重新登錄"); req.setAttribute("return_uri", servletPath); RequestDispatcher rd=req.getRequestDispatcher("/03/login.jsp"); rd.forward(req, resp); }else{ req.setAttribute("msg","你尚未登錄"); req.setAttribute("return_uri", servletPath); RequestDispatcher rd=request.getRequestDispatcher("/03/login.jsp"); rd.forward(req, resp); } } System.out.println(servletPath); }
容器在加載的時候,會讀取web.xml中的<filter></filter>,根據指定的類路徑來實例化過濾器。
那么過濾器究竟是用來做什么的呢?
顧名思義,過濾器肯定是過濾我們不想要的東西。所以說執行肯定是在我們訪問某個頁面之前。所以發散開來,它也可以執行一些我們在訪問某個頁面,或者某些頁面之前想要的操作。
那么:
a.什么是過濾器?過濾器和普通類有什么區別?
b.過濾器中的chain.doFilter()起什么作用?
所以說chain.doFilter(request,response)是過濾器的必要操作,目的是如果有多個過濾器需要處理同一個url時把請求傳給下一個過濾器。
c.過濾器的處理的先后順序?
<servlet-mapping> <servlet-name>myServlet</servlet-name> <url-pattern>/foo*</url-pattern> </servlet-mapping> <filter-mapping> <filter-name>servletFilter</filter-name> <url-pattern>myServlet</url-pattern> </filter-mapping> <filter-mapping> <filter-name>myFilter</filter-name> <url-pattern>/foo*</url-pattern> </filter-mapping> <filter-mapping> <filter-name>anotherFilter</filter-name> <url-pattern>/foo/bar</url-pattern> </filter-mapping>
如果一個普通的請求訪問的URL是/foo/bar,那么它將匹配所有這3個過濾器。過濾器鏈將由3個過濾器組成,依次為myFilter、anotherFilter,然后是servletFilter。myFilter將在anotherFilter之前執行,因為這是它們出現在部署描述符中的順序。它們都將在servletFilter之前執行,因為URL映射總是在Servlet名稱映射之前執行。
關于如何進行Java過濾器doFilter里chain.doFilter()函數的理解就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。