内容简介:最近项目中遇到各种输出数据监控,数据校验等逻辑,一个个实现很是麻烦。项目是中途接手的,不是很熟悉,偶然一天发现项目中对 Filter 的使用扩展起来很是方便,所以,今天楼主来分享下,也为自己学习做个记录。下面我们从三方面来阐述。Filter 在设计模式里面被称为责任链设计模式,顾名思义,我们可以在这条责任链上对一组数据做不同的处理。这种类型的设计模式属于结构型模式,它结合多个标准来获得单一标准。定义 Filter 接口,接口中定义进行数据处理的方法。
最近项目中遇到各种输出数据监控,数据校验等逻辑,一个个实现很是麻烦。项目是中途接手的,不是很熟悉,偶然一天发现项目中对 Filter 的使用扩展起来很是方便,所以,今天楼主来分享下,也为自己学习做个记录。下面我们从三方面来阐述。
什么是 Filter
Filter 在 设计模式 里面被称为责任链设计模式,顾名思义,我们可以在这条责任链上对一组数据做不同的处理。这种类型的设计模式属于结构型模式,它结合多个标准来获得单一标准。
怎么用 Filter 项目中的代码实现逻辑
定义 Filter 接口,接口中定义进行数据处理的方法。
public interface IDataHandlerFilter { void filter(DataPackage dataPackage); }
统一数据发送端,将业务系统处理好的数据,统一发送到 kafka。当然我们还可以实现 Filter 对数据进行其他处理。
public class DataSendHandlerFilter implements IDataHandlerFilter { public static final Logger log = LogManager.getLogger(DataSendHandlerFilter.class); private int logCenterType; //数据源类型 0-实时数据 1-wifi数据 private String resourceType = StringUtils.isBlank(Repository.getCityConfig().getResourceType()) ? "0" : Repository.getCityConfig().getResourceType(); public DataSendHandlerFilter() { logCenterType = Repository.getSysConfig().getLogCenterType(); //初始化kafka if (logCenterType == Constant.LogcenterType.KAFKA){ KafkaProducerHelper.init(Repository.getCityConfig().getCityId(), Repository.getSysConfig()); log.info("初始化kafka"); } } @Override public void filter(DataPackage dataPackage) { GpsData gpsData = dataPackage.getTargetData(); /*重复数据和时间格式错误数据不发送*/ if (null != gpsData && !gpsData.isError() && logCenterType == Constant.LogcenterType.KAFKA) { if (gpsData.isGps()) { KafkaProducerHelper.sendData(gpsData.toGpsStr(resourceType)); } if (gpsData.isStn()) { KafkaProducerHelper.sendData(gpsData.toStnStr(resourceType)); } } } }
设置系统要使用的 Filter ,根据具体业务有所不同。
public class HanderFilterUtil { private static List<IDataHandlerFilter> list; /** * 这个是有先后顺序的 * @return */ public static List<IDataHandlerFilter> getDefaultFilter(SysConfig sysConfig, CityConfig cityConfig){ if (null == list){ list = new ArrayList<>(); } //默认提供接收日志、重复校验、时间格式校验、属性校验、数据转发过滤器 list.add(new RepeatHandlerFilter()); list.add(new DataLogHandlerFilter()); list.add(new DataSendHandlerFilter()); // ...... return list; } }
最后我们通过调用 getDefaultFilter 方法来决定我们系统中使用哪几种 Filter 来处理数据。
以上所述就是小编给大家介绍的《Filter 设计模式编码实践》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 编码、摘要和加密(一)——字节编码
- 新媒体编码时代的技术:编码与传输
- MySQL数据库字符编码总结--数据传输编码
- PHP 开发者学 Golang 之 URL 编码 (Urlencode)、解编码 (Urldecode)
- ios平台实现视频H264硬编码及软编码(附完整demo)
- Python 中文编码
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Java多线程编程实战指南(设计模式篇)
黄文海 / 电子工业出版社 / 2015-10 / 59.00
随着CPU 多核时代的到来,多线程编程在充分利用计算资源、提高软件服务质量方面扮演了越来越重要的角色。而 解决多线程编程中频繁出现的普遍问题可以借鉴设计模式所提供的现成解决方案。然而,多线程编程相关的设计模式书籍多采用C++作为描述语言,且书中所举的例子多与应用开发人员的实际工作相去甚远。《Java多线程编程实战指南(设计模式篇)》采用Java(JDK1.6)语言和UML 为描述语言,并结合作者多......一起来看看 《Java多线程编程实战指南(设计模式篇)》 这本书的介绍吧!