簡介:
鏈接上文:https://www.cnblogs.com/0099-ymsml/p/16139618.html
請求、轉發、包含、錯誤
REQUEST、FORWARD、INCLUDE、ERROR
需要在web.xml中的Filter的<dispatcher>標簽里面進行配置:
<dispatcher>INCLUDE</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>REQUEST</dispatcher>
<dispatcher>ERROR</dispatcher>
默認攔截方式為REQUEST,沒有配置的話攔截方式就是REQUEST,但是如果配置了其余的攔截方式,那么攔截方式就是配置的而不是默認的REQUEST了;
現在配置一個FORWARD轉發攔截方式並通過訪問BServlet轉發至AServlet:
AServlet:
package demo1;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/AServlet")
public class AServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("------Aervlet-----");
}
}
BServlet:
package demo1;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/BServlet")
public class BServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("----------- BServlet ---------");
req.getRequestDispatcher("/AServlet").forward(req, resp); //轉發
}
}
web.xml配置:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" id="WebApp_ID" version="4.0">
<display-name>day0412_1</display-name>
<filter>
<filter-name>AFilter</filter-name> <!-- 自定義名稱 -->
<filter-class>demoFilter.AFilter</filter-class> <!-- Filter類所在路徑 -->
</filter>
<filter-mapping>
<filter-name>AFilter</filter-name> <!-- 自定義名稱匹配 -->
<url-pattern>/*</url-pattern> <!-- 攔截的資源路徑 -->
</filter-mapping>
<filter>
<filter-name>BFilter</filter-name> <!-- 自定義名稱 -->
<filter-class>demoFilter.BFilter</filter-class> <!-- Filter類所在路徑 -->
</filter>
<filter-mapping>
<filter-name>BFilter</filter-name> <!-- 自定義名稱匹配 -->
<url-pattern>/AServlet</url-pattern> <!-- 攔截的資源路徑 -->
<dispatcher>FORWARD</dispatcher>
</filter-mapping>
</web-app>
啟動服務器,瀏覽器訪問BServlet:
查看控制台輸出結果:
分析結論:
首先是AFilter攔截成功,因為AFilter攔截方式為默認的REQUEST請求,而訪問BServlet正是這種方式;
然后是AFilter放行,放行后執行BServlet,執行BServlet時會執行BServlet中的轉發操作,那么這個時候就會被BFilter攔截,因為BFilter的攔截方式是FORWARD轉發,隨后BFilter會進行放行,然后執行AServlet。
在AServlet和BServlet的程序結尾添加一局輸出語句后再執行:
可以發現執行順序就是先執行的后結束。