我们可以利用过滤器来实现对用户行为的过滤监控,比如说我们可以在过滤器中记录用户的操作也就是日志记录;或者可以实现图片的保护 ,即用户
不能通过直接输入图片的URL来获得该图片资源,而是要通过链接来查看;还有可以利用过滤器来实现监控资源的访问情况
Servlet API中给我们提供的接口有Filter,FilterCOnfig和FilterChain
主要有三个实现方法:init doFilter和destroy
我们可以通过@WebFilter注解来配置过滤器,它主要有filterName,initParams,urlPattern,servletNamesd等属性
eg:
@WebFilter(filterName = "LoggingFilter", urlPatterns = { "/*" }, initParams = {
@WebInitParam(name = "logFileName", value = "log.txt"),
@WebInitParam(name = "prefix", value = "URI:") })
public class LoggingFilter implements Filter {
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("doFilter");
HttpServletRequest httpRequest = (HttpServletRequest) request;
writer.println(new Date() + " " + httpRequest.getRequestURI());
writer.flush();
chain.doFilter(request, response);
}
}//记录用户的访问记录到输出到文件中
还有我们在过滤图片访问的时候,
在doFilter方法中调用request.getHeader("referer");
如果返回的结果为空就不能访问等等