基于Spring的web服务端逻辑代码层次及对应职责的一点想法

引子

根据Robert C.Martin在《敏捷软件开发-原则、模式与实践》一书的观点,一个基本满足敏捷开发的代码应该符合以下5个原则:
SRP  单一职责原则
    就一个类而言,应该仅有一个引起它变化的原因。
OCP  开放一封闭原则
    软件实体(类、模块、函数等)应该是可以扩展的,但是不可修改。
LSP  Liskov替换原则
    子类型必须能够替换掉它们的基类型。
ISP  接口隔离原则
    不应该强迫客户依赖于它们不用的方法。接口属于客户,不属于它所在的类层次结构。
DIP  依赖倒置原则
    抽象不应该依赖于细节。细节应该依赖于抽象。
但在现实中,由于各个各样的原因,系统中总会有这样那样不符合这5个原则的地方。
这样的代码维护起来就两个字: 累  乱。
一个理想的系统,代码层次应该是这样的:
 

较理想的代码层次和职责

 

层次职责允许的操作不允许的操作
外部入口层(输入入边界)接收外部请求,封装成代码内部可用数据读取各种外部输入资源,如http请求,文件等直接调用基础服务
包括直接调用dao,mc,mq等
接口服务层校验请求数据的格式合法性,并调度各个业务服务,串联推动业务服务 无特殊情况,不直接调用基础服务层
业务服务层进行一个和多个领域模型之间的业务的封装,
 
缓存各种独立在db外的信息
可配合工具类实现领域对象的重新封装
 
领域服务层提供单个领域的各种操作,如增删改查。

缓存各种基于db的列表信息
可配合工具类实现领域对象的重新封装
 
基础服务层提供基础的存储和外部服务依赖的dao服务:可对应db行记录缓存领域对象dao服务无特殊情况不缓存 领域对象的列表
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值