仅限单体应用!!!
单体应用有时会有一些综合数据的模块, 比如考评、报表、综合查询等。在maven里面直接把jar包移过来会产生循环依赖以及后期导致依赖混乱的问题。对业务模块的独立性也不是很友好。违背了迪米特法则。后期维护性、模块可移植性都很差。因此,在组件包里面设置了一个数据提供者的接口。模块间通过该接口进行数据交互。传输内容权通过json来传输。模块只需编写自已的数据提供接口的实现类接口即可。而综合数据模块也能取到需要的模块数据。原理也很简单,如下图:
DataProvider:
public interface DataProvider {
boolean supportCode(String code);
void load(DataContent content);
}
context
public class DataContent {
private String jsonParam;
private String jsonResult;
... 一些获取参数,结果的方法
}
综合数据模块拉取需要的数据示例:
private List<EvaluatorElement> loadElements(String batchId) {
...
// 拉取的参数
DataContent content = new DataContent();
content.putParam("startTime", evaluatorBatch.getStartTime());
content.putParam("endTime", evaluatorBatch.getEndTime());
List<EvaluatorElement> elements = new ArrayList<>();
for (DataProvider dataProvider : dataProviders) {
if (dataProvider.supportCode("uniterEvaluator")) {
dataProvider.load(content);
String jsonResult = content.getJsonResult();
List<EvaluatorElement> els =JSONArray.parseArray(jsonResult, EvaluatorElement.class);
elements.addAll(els);
}
}
return elements;
}
业务模块提供数据示例:
@Componet
public class XXXDataProvider implements DataProvider {
@Override
public boolean supportCode(String code) {
return "uniterEvaluator".equals(code);
}
@Override
public void load(DataContent content) {
// 查找培训
Long startTime = content.getParamLong("startTime");
Long endTime = content.getParamLong("endTime");
...
List<EvaluatorElement> elements = buildElement(startTime,endTime);
...
content.putResults(elements);
}
实际使用效果还可以。两个模块开发人员沟通供需数据就可以了。不用直接把模块的坐标依赖过来。也不要去依赖对方的类。两边通过json沟通。单体项目中,模块的独立性得到了保障。