浅谈微服务-POJO

POJO的定义

按照阿里巴巴规范,是DTO,VO,BO等的统称。任何模型不许定义为***POJO。

实际模型

Entity 数据库
DTO 系统间传输对象
BO 业务级大对象, 一般 用于一个复杂对象场景下使用
VO 页面显示对象
Result -> 一种特殊的DTO,用于定义服务间数据传输的包装类

Result

属性一般有:String code; String message; T data; Boolean success;
其中code 和message 不允许显式的声明定义,需要使用枚举类。
Result 提供统一的sucess() 方法。需要判断Boolean 或者 code值,这个视具体接口而定,一般建议使用Boolean 判断, 使用code细分具体场景。
提供统一的创建对象的方法。

VO 包装类也需用Result包装。

传输入参和出参严禁使用Map对象处理,数据库亦如此,因为可读性很弱,且不方便维护,传递过程中,都需要保证key的正确性。

微服务中,DTO 传输对象不能直接使用数据库对象

微服务中,不管是使用SpringCloud 或者使用 RPC, 在传输时,基本输出对象都和数据库一致,但业务发展中,总会需要新字段支撑,那样不利于维护。
比如:现在一个接口返回学生id,后续需要返回用户父母信息,后续改动就较大了。

微服务间传输尽可能的返回其他使用者可能需要的信息

这个主要防止重复造轮子,或者重复修改老接口。
如果新接口需要使用某字段,直接拿来用,迭代就很快。如果某个字段需要调整老接口,或者新增接口,会导致项目越来越臃肿,且后期可能需要修改多个接口。
微服务间,数据尽可能的传递,最终有端服务去决定哪些数据作为VO输出。

对象属性

有个接口如果即有用户信息,又有家长信息,还有其他信息,请将多个维度的信息封装成对象属性。
不然后期维护会导致对象越来越多,且不能清晰标识这个接口具体做哪些事情。虽然接口注释中可以描述,但如果区分清晰,使用者会更加明确结果内容。

明确输出字段

这个弱场景中涉及到,比如两个接口公用一个输出类,但A接口会输出全部信息,B接口为效率考虑,输出部分字段,需要接口中明确。

POJO转化

mapstruct
DozerMap
BeanUtils.copy**
get/set

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值