过滤器是处于客户端与服务器资源之前的一道过滤技术
1.过滤器作用
过滤器执行在Servlet之前,客户端发送请求时,会先经过过滤器Filter,在到达目标Servlet当中。从而实现一些特殊的功能。例如实现URL级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能。
2.编写过滤器
拦截器代码
@WebFilter("/tage") //设置拦截的目标,也及时该目标的访问地址
public class MyFilter implements Filter{// 初始化方法
@Override
public void init(FilterConfig filterConfig) throws ServletException {// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {System.out.println("执行拦截器");
// 让请求继续执行到拦截的servlet当中去
chain.doFilter(request, response);
//执行完毕返回
System.out.println("执行完毕返回");
}
//效果方法
@Override
public void destroy() {// TODO Auto-generated method stub
}
}
目标代码
@WebServlet("/tage")
public class TageServlet extends HttpServlet{ @Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { System.out.println("我是目标servlet");
}
}
3.在web.xml中配置过滤器
过滤器代码
public class MyFilter implements Filter{@Override
public void init(FilterConfig filterConfig) throws ServletException {// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException { System.out.println("我执行啦 ");
//继续执行剩下的过滤器
chain.doFilter(request, response); //让目标资源执行,放行
}
@Override
public void destroy() {// TODO Auto-generated method stub
}
}
xml当中的配置
myFilter com.qcby.MyFilter myFilter /*
4.关于拦截路径
拦截器的拦截路径通常有三种方式
精确匹配拦截:比如/index.jsp /tage
后置匹配拦截:比如*.html *.jsp
通配符拦截匹配/* 表示拦截所有。注意过滤器不能使用 / 匹配
5.过滤器链和优先级
客户端对服务器请求后,服务器在调用Servlet之前会调用一组过滤器(多个过滤器),那么这组过滤器就称为一组过滤链。
每个过滤器都有特定的功能,当一个过滤器的doFilter()方法被被调用后,Web服务器会创建一个代表Filter链的FilterChain对象传递该方法。在doFilter方法中,开发人员如果调用了FilterChain对象的doFilter()方法,则Web服务器会检查FilterChain对象中是否还有filter,如果有,则调用第2个filter,如果没有,则调用目标资源。
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款