java 过滤器映射_filter映射:filter的两种映射方式

Filter拦截的资源需要在web.xml文件中进行配置,即Filter映射。Filter的映射方式可分为两种,具体如下:

1、使用通配符“\”拦截用户所有请求

Filter的元素可以配置过滤器所有拦截的资源,如果想让过滤器拦截所有的请求访问,那么需要使用通配符“*”来实现,具体示例如下:

Filter1

cn.itcast.chapter04.filter.MyFilter

Filter1

/*

2、拦截不同方式的访问请求

在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

2 pageEncoding="utf-8"%>

3

4

5

6 first.jsp

7

8

(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页面,具体代码如下:

FilterTest

cn.itcast.chapter04.filter.FilterTest

FilterTest

/first.jsp

(5)启动Tomcat服务器,在浏览器中输入URL地址http://localhost:8080/chapter04/ServletTest访问ServletTest,浏览器显示的结果如图1所示。

667e9487cd876978782b6e945467f9dc.png

从图1中可以看出,浏览器可以正常访问JSP页面,说明FilterTest没有拦截到ServletTest转发的first.jsp页面。

(6)为了拦截ServletTest通过forward()方法转发的first.jsp页面,需要在web.xml文件中的增加一个元素,将该元素的值设置为FORWARD,修改后的FilterTest的映射如下所示:

FilterTest

cn.itcast.chapter04.filter.FilterTest

FilterTest

/first.jsp

FORWARD

(7)启动Tomcat服务器,在浏览器的地址拦输入URL地址http://localhost:8080/chapter04/ServletTest访问ServletTest,浏览器显示的结果如图2所示。

c230faa9a0df19e583bbea08c67650a0.png

从图2中可以看出,浏览器窗口显示的是FilterTest中的内容,而first.jsp页面的输出内容没有显示。由此可见,ServletTest中通过forward()方法转发的first.jsp页面被成功拦截了。

猜你喜欢:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值