对服务器接受的请求资源和响应给浏览器的资源进行管理。
保护servlet
创建一个实现了Filter接口的普通java类
覆写接口的方法
init方法:服务器启动即执行。资源初始化
doFilter方法:拦截请求的方法,在此方法中可以对资源实现管理。
注意:
需要手动对请求进行放行。chain.doFilter(request, response);
destory方法:服务器关闭执行。
<filter>
<filter-name>myFilter</filter-name>
<filter-class>com.bjsxt.filter.MyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>myFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
注意:
url-pattern:/*
表示拦截所有的请求。
url-pattern:*.do
表示所有以.do结尾的请求。一般是用来进行模块拦截处理。
url-pattern:/ts
表示拦截指定url的请求。针对某个servlet的请求进行拦截,保护servlet。
服务器启动到服务器关闭。
过滤器程序员声明和配置,服务器根据请求中的uri信息调用。
浏览器发起请求到服务器,服务器接收到请求后,根据URI信息在web.xml中找到对应的过滤器执行doFilter方法,该方法对此次请求进行处理后如果符合要求则放行,放行后如果还有符合要求的过滤则继续进行过滤,找到执行对应的servlet进行请求处理。servlet对请求处理完毕后,也就service方法结束了。还需继续返回相应的doFilter方法继续执行。
统一编码格式设置。
session管理
权限管理
资源管理(统一水印,和谐词汇等等)
<!-- 配置过滤器 --> <filter> <filter-name>myFilter</filter-name> <filter-class>com.bjsxt.filter.MyFilter</filter-class> </filter> <filter-mapping> <filter-name>myFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!--配置第二个过滤器 --> <filter> <filter-name>myFilter2</filter-name> <filter-class>com.bjsxt.filter.MyFilter2</filter-class> </filter> <filter-mapping> <filter-name>myFilter2</filter-name> <url-pattern>*.do</url-pattern> </filter-mapping> <!--配置第三个过滤器 --> <filter> <filter-name>myFilter3</filter-name> <filter-class>com.bjsxt.filter.MyFilter3</filter-class> </filter> <filter-mapping> <filter-name>myFilter3</filter-name> <url-pattern>/ts.do</url-pattern> </filter-mapping>
Java案例
1 public class MyFilter implements Filter{ 2 3 @Override 4 public void init(FilterConfig filterConfig) throws ServletException { 5 System.out.println("MyFilter.init(我被初始化了)"); 6 } 7 8 @Override 9 public void doFilter(ServletRequest request, ServletResponse response, 10 FilterChain chain) throws IOException, ServletException { 11 System.out.println("MyFilter.doFilter(我被执行了)"); 12 //设置编码格式 13 request.setCharacterEncoding("utf-8"); 14 response.setContentType("text/html;charset=utf-8"); 15 //判断session 16 HttpSession hs=((HttpServletRequest) request).getSession(); 17 if(hs.getAttribute("user")==null){ 18 ((HttpServletResponse)response).sendRedirect("/a/login.jsp"); 19 }else{ 20 //放行 21 chain.doFilter(request, response); 22 } 23 System.out.println("MyFilter.doFilter(我被执行了2)"); 24 } 25 26 @Override 27 public void destroy() { 28 System.out.println("MyFilter.destroy(我被销毁了)"); 29 } 30 31 }
原文:https://www.cnblogs.com/sunny-sml/p/12584989.html