虽然只是Servlet的最前端功能,但是其想法还是相当巧妙的。
目的:request,response参数 通过两个过滤器 HTMLFilter SesitiveFilter 过滤掉一些非法内容。
两个过滤器都是先对request做处理,再对response做处理,要求执行顺序是:request参数 先
执行HTMLFilter,再执行SesitiveFilter,response则反向调用。
文件目录:
Filter为接口,HTMLFilter和SesitiveFilter分别实现了Filter,MessageProcess 是对接口的调用,Main则执行MessageProcess的方法。
1.main 调用Processor方法
2.processor调用 HTMLFilter方法执行request
3.HTMLfilter反调Processor方法
4.rocessor方法执行requestSessitiveFilter
5.Sesitive反调Processor
6.Proces 返回空到 SesitiveFilter,SesitiveFilter执行response
7.SesitiveFilter执行完,返回Processor,再返回HTMLFilter ,HTMlFilter继续执行response方法
processor方法代码:
if(i==filters.size())return;
Filter s=filters.get(i);
i++;
s.doFilter(request, response, mp);
定义变量i,接收自己作为参数,然后知道在执行哪一个Filter。