设计模式——责任链

原创 2012年03月23日 15:19:49

责任链模式(Chain of Responsibility)的目标是使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递请求,直到有一个对象处理它为止。

在处理用户的请求时可能要根据不同的情况对请求添加不同的处理逻辑,在这时候就可以利用责任链进行设计。当需要添加一个处理逻辑时可以很方便的添加一个处理的节点。

现在我们的需求是处理用户的请求,将用户提交的字符串信息进行层层处理,同时在处理完成之后返回结果时,也要对返回的字符串进行层层处理,而处理返回的情况时其处理的顺序和先前是正好相反的顺序。

首先建立用户的请求和接收对象Request和Response:

package com.lcq.filter;

public class Request {
	String requestStr;

	public String getRequestStr() {
		return requestStr;
	}

	public void setRequestStr(String requestStr) {
		this.requestStr = requestStr;
	}

}

package com.lcq.filter;

public class Response {
	String responseStr;

	public String getResponseStr() {
		return responseStr;
	}

	public void setResponseStr(String responseStr) {
		this.responseStr = responseStr;
	}

}

我们将处理用户信息的逻辑抽象成为一个个的过滤器,进一步抽象出过滤器接口Filter:
package com.lcq.filter;

public interface Filter {
	public void doFilter(Request request, Response response,FilterChain chain);

}

注意在Filte接口中doFilter方法参数中有FilterChain的一个变量,我们再建立FilterChain类:

package com.lcq.filter;

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

public class FilterChain implements Filter {
	List<Filter> filters = new ArrayList<Filter>();
	int index = 0;

	public FilterChain addFilter(Filter f) {
		this.filters.add(f);
		return this;
	}

	@Override
	public void doFilter(Request request, Response response, FilterChain chain) {
		if (index == filters.size())
			return;
		Filter f = filters.get(index);
		index++;
		f.doFilter(request, response, chain);
	}
}

在FilterChain中继承了Filter接口,从而实现了doFilter方法,在FilterChain中又有一个index变量,该变量是用来标记当前访问的是哪一个过滤器,这些过滤器是存放在ArrayList中的,这样用户在使用的时候就可以实现自己的过滤器,编写自己的处理逻辑,从而将自己的过滤器添加到ArrayList中,再调用FilterChain的doFilter方法遍历整个责任链。

下面我们编写三个过滤器:

HTMLFilter类:

package com.lcq.filter;

/**
 * 过滤HTML中的脚本元素
 * @author lcq
 *
 */
public class HTMLFilter implements Filter {

	@Override
	public void doFilter(Request request, Response response,FilterChain chain) {
		request.requestStr = request.getRequestStr().replace("<", "[")
				.replace(">", "] --------HTMLFilter");
		chain.doFilter(request, response, chain);
		response.responseStr += "--------HTMLFilter";
		
	}

}

SesitiveFilter类:

package com.lcq.filter;

public class SesitiveFilter implements Filter {

	@Override
	public void doFilter(Request request, Response response, FilterChain chain) {
		request.requestStr = request.getRequestStr().replace("敏感", "  ")
				.replace("猫猫", "haha------SesitiveFilter");
		chain.doFilter(request, response, chain);
		response.responseStr += "------SesitiveFilter";

	}

}

FaceFilter类:

package com.lcq.filter;

public class FaceFilter implements Filter {

	@Override
	public void doFilter(Request request, Response response, FilterChain chain) {
		request.requestStr = request.getRequestStr().replace(":)",
				"^V^-------FaceFilter");
		chain.doFilter(request, response, chain);
		response.responseStr += "-------FaceFilter";

	}

}

最后编写测试类:

package com.lcq.filter;

public class Main {
	public static void main(String[] args) {
		String message = "敏感词汇,重庆,<script> 躲猫猫 :)";
		Request request = new Request();
		request.setRequestStr(message);
		Response response = new Response();
		response.setResponseStr("response");
		FilterChain fc = new FilterChain();
		fc.addFilter(new HTMLFilter()).addFilter(new SesitiveFilter());

		FilterChain fc2 = new FilterChain();
		fc2.addFilter(new FaceFilter());
		fc.addFilter(fc2);
		fc.doFilter(request, response,fc);
		System.out.println("request = " + request.getRequestStr());
		System.out.println("response = " + response.getResponseStr());
	}

}
在上面的实例中应该注意两个地方:

1.我们建立的FilterChain中继承了Filter接口,所以在测试类中就可以像使用其他的过滤器一样使用FilterChain,大大提高了灵活性;

2.对于实现责任链的访问处理顺序问题,该问题的解决使用的是递归的思想,从而使先调用的结点在处理返回结果时其调用过滤器的顺序是相反的。这种解决方案在Struts和其他框架中实现过滤器和拦截器使用的较为普遍,并且十分巧妙。










版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

设计模式:Filter过滤器

场景1: 每种Filter进行某种处理,将各个Filter连在一起形成一个FilterChain。当需要往FilterChain中加入新的Filter,或者改变各个Filter的处理顺序时,可以方便...

SOA 与OO

牛人的一句话:利用SOA思想做概要分析和概要设计,OO思想做详细设计,这就是我对SOA的理解 SOA是一种设计方式,它指导着业务服务(buniess service)在其生命周期内包括创建和使用的方方...

设计模式:Bridge模式

如果你想要写一个游戏,并且想让这个游戏同时支持PC和手机,那么怎么样的设计可以避免写两套代码,并且不影响可扩展性呢?说起来还是比较简单的,只要把对平台的依赖部分抽取成抽象的接口(比如说绘图部分),并且...

设计模式——责任链(ChainOfResponsibility)学习笔记

经验:一定要写才能学得会。

设计模式初探——责任链 c语言版

刚开始学设计模式,也没按套路出牌,直接从行为型模式入手,查了查责任链,感觉和工作流联系挺大,或者说是业务流程,或者成为办公自动化。 曾经用过工作流,在公司里,比我我发起了一个工作流,下一步流到小组长那...

java设计模式——责任链

责任链模式(Chain of Responsibility)的目标是使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递请求,直到有一个对象处...
  • lycdx
  • lycdx
  • 2013年08月29日 20:00
  • 467

设计模式(13)——责任链(Chain of Responsibility)

责任链是什么? 责任链条模式使多个对象都有机会处理请求。打个比方说,责任就是得分,多个对象就是篮球队员,在三分线的远投的时候,球由投手投篮。带球突破则由后卫负责。。。 责任链模式的适用范围 1. ...

设计模式学习笔记——责任链(Chain of Responsibility)模式

设计模式学习笔记——责任链(Chain of Responsibility)模式@(设计模式)[设计模式, 责任链模式, chain of responsibility]设计模式学习笔记责任链Chai...

Java设计模式之——责任链模式

责任链模式简单介绍责任链模式,是行为性设计模式之一。什么是“链”?我们将多个节点首尾相连构成的模型称为链,比如生活中常见的锁链,就是由一个个圆角长方形的铁环串起来的结构。对于链式结构,每个节点都可以被...
  • AkaiC
  • AkaiC
  • 2016年10月31日 17:47
  • 457

JAVA设计模式学习——责任链模式

原文: http://alaric.iteye.com/blog/1926447 责任链(Chain of Responsibility)模式 :责任链模式是对象的行为模式。使多个对...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:设计模式——责任链
举报原因:
原因补充:

(最多只允许输入30个字)