单体应用内,一种模块与模块间解耦合的土办法

仅限单体应用!!!
单体应用有时会有一些综合数据的模块, 比如考评、报表、综合查询等。在maven里面直接把jar包移过来会产生循环依赖以及后期导致依赖混乱的问题。对业务模块的独立性也不是很友好。违背了迪米特法则。后期维护性、模块可移植性都很差。因此,在组件包里面设置了一个数据提供者的接口。模块间通过该接口进行数据交互。传输内容权通过json来传输。模块只需编写自已的数据提供接口的实现类接口即可。而综合数据模块也能取到需要的模块数据。原理也很简单,如下图:
单体应用内,一种模块与模块间解耦合的土办法_第1张图片
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沟通。单体项目中,模块的独立性得到了保障。

你可能感兴趣的:(java)