一、简介
过滤器,Servlet技术中最实用的技术,Web开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊的功能。例如实现URL级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能。
二、工作方式
三、创建和使用过滤器
这里我们创建一个过滤器来对编码格式进行过滤
在你的项目里创建一个类来接Filter
注:
public class CharFilter implements Filter {
public void destroy() {//销毁
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
request.setCharacterEncoding("utf-8");//设置编码格式为utf-8
chain.doFilter(request, response);//如果还有过滤器,就跳转到下一个过滤器进行过滤,如果没有,跳转到你所访问的页面
}
public void init(FilterConfig arg0) throws ServletException {//创建
}
}
然后我们来配置xml文件
<filter>//指定一个过滤器。
<description></description>
<display-name>CharFilter</display-name>
<filter-name>CharFilter</filter-name>// Filter的名字
<filter-class>com.ruanyuan.filter.CharFilter</filter-class>// Filter的实现类
</filter>
<filter-mapping>
<filter-name>CharFilter</filter-name>//Filter的名字
<url-pattern>/*</url-pattern>//Filter的过滤地址全部以/开口,/*表示过滤所有的文件,/admin/*表示过滤admin文件夹下的文件,/*.表示过滤jsp文件
</filter-mapping>
在Servlet2.4中filter-mapping中加入了新的标签<dispatcher> ,里面有4个值即REQUEST, FORWARD,INCLUDE和ERROR,默认不写这个标签的时候是REQUEST,该标签是根据客户端传过来的地址进行过滤,FORWARD方法传过来的request方法可以拦截,<ERROR-PAGE>错误页面传过来的拦截,INCLUDE包含过来的过滤,一般REQUEST传过来的拦截.该标签可以加入多个.
注:过滤器的访问顺序是按照你配置文件的顺序进行的。