过滤器filter(一)项目中使用

本文详细介绍了Filter过滤器在Web项目中的应用,包括如何定义Filter类、配置拦截规则,以及其实现的功能,如编码统一设置、敏感词汇操作和URL级别权限访问控制。

filter即我们常说的过滤器,能对web中所有的资源进行拦截,包括jsp,Servlet,图片,HTML文件等等。这样就能实现诸如编码统一设置,敏感词汇操作,URL级别的权限访问控制等等这些功能。

先来看看filter在实际项目中如何定义的?
首先先定义一个filter类,只要实现的了Filter类的类就是filter类(很简单吧)

public class AFilter implements Filter {

    private String filterName;

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        filterName= filterConfig.getFilterName();
        System.out.println("过滤器名称:" + filterName +" init");
    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println(filterName + "  doFilter()");
        filterChain.doFilter(servletRequest, servletResponse);
    }

    @Override
    public void destroy() {

    }
}

然后在web.xml里面配置这个filter类(web.xml在tomcat启动的时候会加载这边相关配置,目前这个不是本篇重点,后续会有对tomcat启动的相关文章,会详细说明,这边只要记住这个点即可),当然这边也可通过注解的方式进行配置。

    <filter>
        <filter-name>BFilter</filter-name>
        <filter-class>module.filter.BFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>BFilter</filter-name>
        <url-pattern>/filter.jsp</url-pattern>
    </filter-mapping>

这样就能拦截**/filter.jsp*
如果想要拦截所有的请求,就可以配置成 ‘/*’即可

    <filter>
        <filter-name>name</filter-name>
        <filter-class>class</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>name</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值