asp.net

DTO类

2023-04-28

关于DTO的一点小知识:

经常接触到VO,DO,DTO的概念,本文从领域建模中的实体划分和项目中的实际应用情况两个角度,对这几个概念进行简析。

    得出的主要结论是,在项目应用中,VO对应于页面上需要显示的数据(表单),DO对应于数据库中存储的数据(数据表),DTO对应于除二者之外需要进行传递的数据。

一、实体类

我们常说实体对象,实体对象,那什么是实体对象?

实体类的主要职责是存储和管理系统内部的信息,它也可以有行为,甚至很复杂的行为,但这些行为必须与它所代表的实体对象密切相关。

根据以上定义,我们可以了解到,实体类有两方面内容,存储数据和执行数据本身相关操作。这两方面内容对应到实现上,最简单的实体类是POJO类,含有属性及属性对应的set和get方法,实体类常见的方法还有用于输出自身数据的toString方法。

我们在写项目时,一般会把一个物体抽象出来给予一些属性,向我们用户所拥有的用户名密码等,包含了它的get以及set方法的类我们可以称之为实体类,在该类下一般不会有太多的方法用于操作,这样一个是便于管理,第二个是信息安全。

二、领域模型中的实体类

    领域模型中的实体类分为四种模型:VO,DTO,DO,PO,各类实体类用于不同业务层次间的交互,并会在层次内实现实体类之间的转化。

    业务层分为:视图层(VIEW+ACTION),服务层(SERVICE),持久层(DAO)

    我们平常所说的MVC框架,可以理解为一个抽象的框架。这个MVC是告诉我们在开发过程中,我们要将代码进行解耦(减少交叉调用,尽量使每一个类功能单一),目的是为了便于维护和二次开发,也使得我们的开发逻辑变得清楚。M:model层,是将数据持久化层,即DAO层,我们一般把数据库的一些方法写在DAO这个文件夹之下。V:view是视图层,将前端模板信息放在这里,C:Controller,控制层,在项目中,项目逻辑几乎都在这一层。

   但我们在开发中并不仅仅是建立三个包一个叫model,一个叫view,另一个叫controller。这三层只是逻辑上的三层,我们后端开发过程中将接口(用于接收前端返回参数,一般为Json格式,可以向服务器传输的三种格式,HTML,Json以及XML)预留好,就可以了,在前端中也是有自己的逻辑的,比如简单的Ajax去判断密码用户名格式,(但是有小伙伴问前端已经验证过,后端是不是不需要验证,显然不可以,且不说总有一篇发烧友,直接使用爬虫对服务器进行访问之外,还有一个叫无界面浏览器也可以绕开前端的检验,减少一些不必要的请求来减少服务器和数据库的压力是很有必要的,每一次消息互传可以说都是一次消耗,很烧钱的)。我们这么做主要是减少开发成本,小伙伴们可以想一想,作为一个后端开发工程师,在很少使用到JS,CSS,HTML的时候,在代码里出现大量的这种前端语言,是否会大大降低代码的可读效率,在开发过程中别人需要使用或者说之后再次复用该接口的时候是否会没办法复用。当然不排除天赋异禀的小伙伴(全栈工程师),但是一个项目的开发大多数是团队开发,并不是向学校项目一样是一个人可以简单制作一个页面加自己做后端逻辑系统加自己进行库表设计即可完成的,团队中总有一些不是天赋那么异禀的小伙伴,而且全栈工程师也应该去做跟复杂的事情,术业有专攻。但项目中我们并没有严格遵循这种传递关系,但这种和业务层次的关联对我们理解各实体类的作用是有帮助的。

概念:

    DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对象。

    VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。

    DO(Domain Object):领域对象,就是从现实世界中抽象出来的有形或无形的业务实体。

    PO(Persistent Object):持久化对象,它跟持久层(通常是关系型数据库)的数据结构形成一一对应的映射关系,如果持久层是关系型数据库,那么,数据表中的每个字段(或若干个)就对应PO的一个(或若干个)属性。

场景:

    用户发出请求(提交登录的表单),表单的数据在展示层被匹配为VO。

    展示层把VO转换为服务层对应方法所要求的DTO,传送给服务层。

    服务层首先根据DTO的数据构造(或重建)一个DO。调用DO的业务方法完成具体业务。

    服务层把DO转换为持久层对应的PO(可以使用ORM工具,也可以不用),调用持久层的持久化方法,把PO传递给它,完成持久化操作。

    对于一个逆向操作,如读取数据,也是用类似的方法进行转换和传递,这里就不详细说明了。

三、项目中的实体类

    项目中常见的实体类有VO,DO和DTO,命名规则也常是以相应字符串结尾,如*VO.Java。但是DTO不总是遵循这个规则,而通常与他的用途有关,如写成*Query.java,表示存储了一个查询条件。项目中实体类出现的业务层次也没有这么严格,例如我们可以在视图层就组装一个DO,也可以将一个VO从持久层传出来,所以与业务分层相关联的划分方法显得有些冗余。从项目代码中抽象出的理解是:VO对应于页面上需要显示的数据,DO对应于数据库中存储的数据,DTO对应于除二者之外需要进行传递的数据。