Filter執(zhí)行過程是什么
Filter執(zhí)行的順序
馬克- to-win:馬克 java社區(qū):防盜版實(shí)名手機(jī)尾號: 73203。
馬克-to-win:根據(jù)上面的說明“Filter的攔截的工作過程”的圖,我們對Filter的Helloworld例子做一個(gè)小小的擴(kuò)展(增加了一個(gè) MarkToWinFilter2,代碼和MarkToWinFilter幾乎一樣),來說明Filter的順序,結(jié)論:filter-mapping在Web.xml中的順序決定了Filter執(zhí)行的順序。
例 1.2.3
Web.xml中增加下一段:
<filter>
<filter-name>MarkToWinFilter2</filter-name>
<filter-class>com.MarkToWinFilter2</filter-class>
</filter>
<filter>
<filter-name>MarkToWinFilter</filter-name>
<filter-class>com.MarkToWinFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>MarkToWinFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>MarkToWinFilter2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
package com;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.*;
public class MarkToWinFilter2 implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
response.setCharacterEncoding("GBK");
PrintWriter out = response.getWriter();
out.println("之前 filterChain.doFilter2");
System.out.println("之前 filterChain.doFilter2");
chain.doFilter(request, response);
System.out.println("之后 filterChain.doFilter2");
out.println("之后 filterChain.doFilter2");
}
public void init(FilterConfig fConfig) throws ServletException {
}
}
在瀏覽器中,當(dāng)運(yùn)行home.jsp時(shí),瀏覽器中輸出的結(jié)果是:
之前 filterChain.doFilter 之前 filterChain.doFilter2
這是在home.jsp
之后 filterChain.doFilter2 之后 filterChain.doFilter
同時(shí)Console中輸出的結(jié)果是:
之前 filterChain.doFilter
之前 filterChain.doFilter2
inside jsp
之后 filterChain.doFilter2
之后 filterChain.doFilter