Java過濾器doFilter裡chain.doFilter()函數的理解
對過濾器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); }
過濾器Filter&&chain.doFilter()
容器在加載的時候,會讀取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名稱映射之前執行。
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Java filter中的chain.doFilter使用詳解
- Java 使用Filter實現用戶自動登陸
- springmvc字符編碼過濾器CharacterEncodingFilter的使用
- CorsFilter 過濾器解決跨域的處理
- Java CharacterEncodingFilter案例詳解