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

被折叠的 条评论
为什么被折叠?



