在DTO中使用注解的形式检验数据是否为空,为什么这么做

在这里插入图片描述
如上图,在一个DTO中使用了注解的形式进行参数的非空验证,为什么要这么做呢?
为什么不直接在使用时对参数进行非空验证呢?
首先说一下DTO的作用,表现层与应用层之间是通过数据传输对象(DTO)进行交互的,数据传输对象是没有行为的POCO对象(POCO就是简单CLR对象(Plain Old CLR Object),概念来源于Java中的POJO),它 的目的只是为了对领域对象进行数据封装,实现层与层之间的数据传递。为何不能直接将领域对象用于数据传递?因为领域对象更注重领域,而DTO更注重数据。不仅如此,由于“富领域模型”的特点,这样做会直接将领域对象的行为暴露给表现层。
并且,数据传输对象DTO本身并不是业务对象。数据传输对象是根据前台的需求进行设计的,而不是根据领域对象进行设计的。比如,company领域对象可能会包含一些诸如companyName,companyCode, Address等信息。但如果前台上不打算显示Address的信息,那么CustomerDTO中也无需包含这个 Address的数据。
在DTO中对非业务的数据进行验证,例如是否为空,并不需要业务上的验证,主要还是为了减少后台的校验过程,使代码更加简洁规范;而类似用户名是否重复这样需要业务上的验证的,是需要交给对应的controller层下的service进行处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值