过滤器初体验

本文介绍了如何实现和配置Web应用程序中的过滤器。通过编写Filter类实现Filter接口,并在web.xml中配置过滤规则,可以对特定资源进行拦截。未开启放行时,访问指定路径将被阻止,开启后才能查看内容,充分体现了过滤器的拦截功能。
摘要由CSDN通过智能技术生成

①编写一个过滤器的类实现Filter接口 并且实现其中的方法 着重实现Filter方法

public class MyFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("quick running");
        filterChain.doFilter(servletRequest, servletResponse);//这是开启放行  不设置就是进行拦截   像保安一样的作用
    }

    @Override
    public void destroy() {

    }
}

②在web.xml文件中进行配置(主要配置要对哪些资源进行过滤)

<filter>
    <filter-name>MyFilter</filter-name>
    <filter-class>com.itheima.web.MyFilter</filter-class>
</filter>

<filter-mapping>
    <filter-name>MyFilter</filter-name>
    <url-pattern>/*</url-pattern> 
</filter-mapping>

③创建一个拦截的对象

@WebServlet(name = "DemoServlet",urlPatterns = "/demo")
public class DemoServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        
            response.getWriter().write("...........");
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request,response);
    }
}

这样在不开启放行的话,访问demo路径是看不到结果的

开启放行的 即可看到结果

filterChain.doFilter(servletRequest, servletResponse);

所以过滤器 顾名思义就是起到过滤的作用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值