随笔都是学习笔记
随笔仅供参考,为避免笔记中可能出现的错误误导他人,请勿转载。

简介:

链接上文: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的程序结尾添加一局输出语句后再执行:

可以发现执行顺序就是先执行的后结束。

 

posted on 2022-04-13 14:19  时间完全不够用啊  阅读(684)  评论(0编辑  收藏  举报