JavaWeb中的Filter

应用场景

  1. 过滤非法请求
  2. 记录请求日志
  3. 设置请求编码
Filter介绍
  1. Filter是Servlet的加强版,主要用于对用户请求进行预处理,对HttpServletResponse进行后处理。
  2. Filter的处理流程是:Filter对请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对响应进行后处理。
  3. Filter在HttpServletRequest到达Servlet之前,拦截客户的HttpServletRequest;根据需要检查HttpServletRequest,也可以修改HttpServletRequest头和数据;在HttpServletResponse到达客户端之前,拦截HttpServletResponse;根据需要检查HttpServletResponse,也可以修改HttpServletResponse头和数据。
Filter使用
  1. 创建Filter处理类。
  2. web.xml文件中配置Filter。

示例代码:

public class HttpHeaderSecurityFilter implements Filter{

    private FilterConfig config;

	@Override
	public void init(FilterConfig filterConfig) throws ServletException {
		this.config = filterConfig; 
	}

	@Override
	public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain)
			throws IOException, ServletException {
		HttpServletRequest request = (HttpServletRequest)req;
		HttpServletResponse response = (HttpServletResponse)resp;
		chain.doFilter(request, response);
	}

	@Override
	public void destroy() {
		
	}

}
<filter>
    <filter-name>httpHeaderSecurity</filter-name>
    <filter-class>cn.org.platform.filter.HttpHeaderSecurityFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>httpHeaderSecurity</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

它和Servlet的配置相似,也可以配置索所要过滤的URL,也可以配置参数。示例代码:

<filter>
    <filter-name>httpHeaderSecurity</filter-name>
    <filter-class>cn.org.platform.filter.HttpHeaderSecurityFilter</filter-class>
	<init-param>
		<param-name>encoding</param-name>
		<param-value>UTF-8</param-value>
	</init-param>
</filter>
public class HttpHeaderSecurityFilter implements Filter{

	......
	
	@Override
	public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain)
			throws IOException, ServletException {
		String encoding = config.getInitParameter("encoding");
		req.setCharacterEncoding(encoding);
		HttpServletRequest request = (HttpServletRequest)req;
		HttpServletResponse response = (HttpServletResponse)resp;
		chain.doFilter(request, response);
	}
	
	......

}

Filter方法

  1. init方法:用于完成Filter的初始化。
  2. destory方法:用于Filter销毁前,完成某些资源的回收。
  3. doFilter方法:实现过滤功能,该方法就是对每个请求及响应增加的额外处理。
  4. Filter随web应用的启动而启动,初始化一次,当web应用停止或重新部署的时候销毁。
  5. Filter可拦截多个请求或响应;一个请求或响应也可被多个Filter拦截,多个Filter时的调用顺序与在web.xml中的前后顺序一致。

Interceptor与Filter

Filter是javax.servlet包中的一个接口。
Interceptor是Spring MVC框架的一部分。
Interceptor和Filter都是AOP编程思想的体现。


参考资料:
  1. https://www.cnblogs.com/junzi2099/p/8022058.html
  2. 《Java EE 企业应用实战 第4版》
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值