更新时间:2020年09月18日14时23分 来源:传智播客 浏览次数:
Filter拦截的资源需要在web.xml文件中进行配置,即Filter映射。Filter的映射方式可分为两种,具体如下:
Filter的元素可以配置过滤器所有拦截的资源,如果想让过滤器拦截所有的请求访问,那么需要使用通配符“*”来实现,具体示例如下:
<filter> <filter-name>Filter1</filter-name> <filter-class>cn.itcast.chapter04.filter.MyFilter </filter-class> </filter> <filter-mapping> <filter-name>Filter1</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
在web.xml文件中,一个元素用于配置一个Filter所负责拦截的资源。 元素中有一个特殊的子元素,该元素用于指定过滤器所拦截的资源被Servlet容器调用的方式,元素的值共有四个,具体如下:
● REQUEST
当用户直接访问页面时,Web容器将会调用过滤器。如果目标资源是通过RequestDispatcher的include()或forward()方法访问时,那么该过滤器将不会被调用。
● INCLUDE
如果目标资源是通过RequestDispatcher的include()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。
● FORWARD
如果目标资源是通过RequestDispatcher的forward()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。
● ERROR
如果目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。
为了大家更好地理解上述四个值的作用,接下来以FORWARD为例,分步骤演示Filter对转发请求的拦截效果,具体如下:
(1)在chapter04工程的cn.itcast.chapter04. filter包中,创建一个ServletTest.java程序,该程序用于将请求转发给first.jsp页面,如例1所示。
例1 ServletTest.java
1 package cn.itcast.chapter04.filter; 2 import java.io.*; 3 import javax.servlet.*; 4 import javax.servlet.http.*; 5 public class ServletTest extends HttpServlet { 6 public void doGet(HttpServletRequest request, HttpServletResponse 7 response) throws ServletException, IOException { 8 request.getRequestDispatcher("/first.jsp") 9 .forward(request, response); 10 } 11 public void doPost(HttpServletRequest request, HttpServletResponse 12 response) throws ServletException, IOException { 13 doGet(request, response); 14 } 15 }
(2)在chapter04工程的WebContent目录中创建一个first.jsp页面,该页面用于输出内容,如例2所示。
例2 first.jsp
1 <%@ page language="java" contentType="text/html; charset=utf-8" 2 pageEncoding="utf-8"%> 3 <html> 4 <head></head> 5 <body> 6 first.jsp 7 </body> 8 </html>
(3)在chapter04工程的cn.itcast.chapter04.filter包中,创建一个FilterTest.java程序,专门用于拦截first.jsp页面,如例3所示。
例3 FilterTest.java
1 package cn.itcast.chapter04.filter; 2 import java.io.*; 3 import javax.servlet.*; 4 public class FilterTest implements Filter { 5 public void destroy() { 6 // 过滤器对象在销毁时自动调用,释放资源 7 } 8 public void doFilter(ServletRequest request, ServletResponse response, 9 FilterChain chain) throws IOException, ServletException { 10 // 用于拦截用户的请求,如果和当前过滤器的拦截路径匹配,该方法会被调用 11 PrintWriter out=response.getWriter(); 12 out.write("Hello FilterTest"); 13 } 14 public void init(FilterConfig fConfig) throws ServletException { 15 // 过滤器对象在初始化时调用,可以配置一些初始化参数 16 } 17 }
(4)在web.xml文件中,配置Filter过滤器,拦截first.jsp页面,具体代码如下:
<filter> <filter-name>FilterTest</filter-name> <filter-class>cn.itcast.chapter04.filter.FilterTest</filter-class> </filter> <filter-mapping> <filter-name>FilterTest</filter-name> <url-pattern>/first.jsp</url-pattern> </filter-mapping>
(5)启动Tomcat服务器,在浏览器中输入URL地址http://localhost:8080/chapter04/ServletTest访问ServletTest,浏览器显示的结果如图1所示。
从图1中可以看出,浏览器可以正常访问JSP页面,说明FilterTest没有拦截到ServletTest转发的first.jsp页面。
(6)为了拦截ServletTest通过forward()方法转发的first.jsp页面,需要在web.xml文件中的增加一个元素,将该元素的值设置为FORWARD,修改后的FilterTest的映射如下所示:
<filter> <filter-name>FilterTest</filter-name> <filter-class>cn.itcast.chapter04.filter.FilterTest</filter-class> </filter> <filter-mapping> <filter-name>FilterTest</filter-name> <url-pattern>/first.jsp</url-pattern> <dispatcher>FORWARD</dispatcher> </filter-mapping>
(7)启动Tomcat服务器,在浏览器的地址拦输入URL地址http://localhost:8080/chapter04/ServletTest访问ServletTest,浏览器显示的结果如图2所示。
从图2中可以看出,浏览器窗口显示的是FilterTest中的内容,而first.jsp页面的输出内容没有显示。由此可见,ServletTest中通过forward()方法转发的first.jsp页面被成功拦截了。
猜你喜欢: