模拟Java Web的Filter责任链模式

我们常常用到拦截器、过虑器等等模式,但是我很少知道,其内部是怎么实现的,不了解其原理。下面就此总结Filter的责任链模式:

第一步,新建一个Filter接口:

package cn.sunline.suncard.dp;

/**
 * 责任链接口
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public interface Filter {

	public void doFilter(Request req, Response res, FilterChain chain);
}

第二步,新建各种具体的Filter实现类:

package cn.sunline.suncard.dp;

/**
 * 敏感字符过虑器
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public class SensitiveFilter implements Filter {

	@Override
	public void doFilter(Request req, Response res, FilterChain chain) {
		req.setReqStr(req.getReqStr().replace("牛B", "牛*"));
		chain.doFilter(req, res, chain);
		res.setResStr(res.getResStr()+this.getClass().getSimpleName()+"--");
	}

}
package cn.sunline.suncard.dp;

/**
 * 特殊字符过虑器
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public class SpecialFilter implements Filter {

	@Override
	public void doFilter(Request req, Response res, FilterChain chain) {
		req.setReqStr(req.getReqStr().replace("$", "¥"));
		chain.doFilter(req, res, chain);
		res.setResStr(res.getResStr()+this.getClass().getSimpleName()+"--");
	}

}
package cn.sunline.suncard.dp;

/**
 * 笑脸字符过虑器
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public class FaceFilter implements Filter {

	@Override
	public void doFilter(Request req, Response res, FilterChain chain) {
		req.setReqStr(req.getReqStr().replace("^_^", "●0●"));
		chain.doFilter(req, res, chain);
		res.setResStr(res.getResStr()+this.getClass().getSimpleName()+"--");
	}

}
第三步,新建FilterChain类(实现自Filter接口):
package cn.sunline.suncard.dp;

import java.util.ArrayList;
import java.util.List;

/**
 * filter链
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public class FilterChain implements Filter {

	private List<Filter> filters = new ArrayList<Filter>();
	int index = 0;
	
	/**
	 * 添加filter
	 * 修改日期:2012-4-26
	 * @author: tpf
	 * @param filter
	 * @return
	 */
	public FilterChain addFilter(Filter filter) {
		this.filters.add(filter);
		return this;
	}
	
	/**
	 * 对各种Filter进行调用
	 */
	@Override
	public void doFilter(Request req, Response res, FilterChain chain) {
		if(index == filters.size()) {
			return;
		}
		Filter filter = filters.get(index);
		index++;
		filter.doFilter(req, res, chain);
	}
}
第四步,还需要新建模拟的Request和Response类:
package cn.sunline.suncard.dp;

/**
 * 模拟请求Request
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public class Request {

	private String reqStr;

	/**
	 * @return the reqStr
	 */
	public String getReqStr() {
		return reqStr;
	}

	/**
	 * @param reqStr the reqStr to set
	 */
	public void setReqStr(String reqStr) {
		this.reqStr = reqStr;
	}
}
package cn.sunline.suncard.dp;

/**
 * 模拟Response
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public class Response {

	private String resStr;

	/**
	 * @return the resStr
	 */
	public String getResStr() {
		return resStr;
	}

	/**
	 * @param resStr the resStr to set
	 */
	public void setResStr(String resStr) {
		this.resStr = resStr;
	}
}
最后,我们写一个测试类:
package cn.sunline.suncard.dp;

/**
 * 责任链dp测试类
 * @author    tpf
 * @version   1.0  2012-4-26
 * @see       [相关类/方法]
 * @since     [产品/模块版本] 
 */
public class FilterTest {

	public static void main(String[] args) {
		String msg = "你是中国人,很牛B,月薪可以达$20000,让人羡慕哈,^_^";
		
		Filter sensitiveFilter = new SensitiveFilter();
		Filter specialFilter = new SpecialFilter();
		Filter faceFilter = new FaceFilter();
		FilterChain filterChain = new FilterChain();
		
		filterChain.addFilter(sensitiveFilter)
				   .addFilter(specialFilter)
				   .addFilter(faceFilter);
		
		Request req = new Request();
		req.setReqStr(msg);
		Response res = new Response();
		res.setResStr("[Response]");
		
		filterChain.doFilter(req,res,filterChain);
		System.out.println(req.getReqStr());
		System.out.println(res.getResStr());
	}

}
以上就是整个Filter拦截器的模拟写法,仅学习而写。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值