简介:
链接上文: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的程序结尾添加一局输出语句后再执行:
可以发现执行顺序就是先执行的后结束。