1.过滤器的作用
对服务器接受的请求资源和响应给浏览器的资源进行管理
保护servlet
2.过滤器的使用
创建一个实现Filter接口的普通java类
覆写接口的方法
init():服务器启动执行,资源初始化
doFilter():拦截请求的方法,在此方法中可以对资源实现管理
注意:
需要手动对请求进行放行,chain.doFilter(request,response)
destroy():服务器关闭执行
在web.xml中配置过滤器
<!--配置过滤器--> <filter> <filter-name>myFilter</filter-name> <filter-class>com.mxj.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管理
权限管理
资源管理(统一水印,和谐词汇等等)
public class MyFilter implements Filter { @Override public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException { //设置编码格式 req.setCharacterEncoding("utf-8"); resp.setContentType("text/html;charaset=utf-8"); //判断session HttpSession hs=((HttpServletRequest) req).getSession(); if(hs.getAttribute("user")==null){ ((HttpServletResponse)resp).sendRedirect("/a/login.jsp"); } else{ //放行 chain.doFilter(req, resp); } } }