Filter過濾器四種攔截方式


簡介:

鏈接上文: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的程序結尾添加一局輸出語句后再執行:

可以發現執行順序就是先執行的后結束。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM