场景说明
背景
本文的背景: 需要开发一个微信公众号后台,对用户输入的关键词进行相应的回复。
如果采用传统的If else,会发现大量的判断分支和业务实现代码混合在同一个类中,在多人开发时候极易出现代码冲突,切代码难以阅读,同时在分支出现调整需求时也难以随心所欲的调整。因此需要一种模式能够将各个条件分支下的处理逻辑分离开来,并且做到可以随时配置调整。
难点
从上边的场景描述不难想到责任链设计模式,但是特殊的地方在于,我们的业务处理部分需要进行一些查询操作时候用到了Spring管理的一些服务类,需要注入到责任链处理节点中去。一般网络上找到的教程均为手动声明类,并初始化的情况,无法结合Spring的特性。后来找到了一篇文章描述了如何在Spring环境下使用责任链设计模式。链接在此
代码说明
要点
- 参考网关zuul 的filter配置风格,即包含: doParse, order, parserType三种关键参数,对于多种业务分支可以配置多种责任链
- Spring支持一次性将一个接口的所有实现类一次性载入进来
- 借用Ordered 接口 实现责任链的先后排序
关键代码
接口&抽象类
首先需要一个Parser的基础,就做一件事 doParse
/*
* 处理节点接口
*/
public interface ISupport {
void doParse(ChainRequestWrapper wrapper) throws Exception;
}
/*
* 处理节点虚类
*/
public abstract AbsSupport implements ISupport, Ordered {
protected AbsSupport support;
protected boolean shouldParse = false;// 默认不参与处理
protected String parserType;
protected int order = Ordered.LOWEST_PRECEDENCE;// 默认最低
// ...下边一堆 getter setter
}
/*
* 处理节点如餐
*/
public class ChainRequestWrapper {
WxMsgDTO dto;
boolean shouldParse