在 spring 的项目中,是返回实体(entity) 还是 dto 好

2020-12-03 13:22:46 +08:00
 glacial

各位 老铁 你们在做项目的时候是怎么返回的信息的

  1. 返回 entity 的好处不用创建很多个 dto 可以节省时间 修改字段时只用修改一处即可

  2. dto 不用暴露过多的字段 当然了可以通过 JsonIgnore 去控制 ,只是不能跟据不同的业务场景去控制字段显示, 缺点是 修改字段后都得去修改对应的 dto , 如果用的是 jpa 还得进行转换

只想的这些 欢迎补充

4073 次点击
所在节点    Java
16 条回复
comsweetcs
2020-12-03 13:27:21 +08:00
DTO...数据传输对象。你说的一般是返回 VO 才对,dto 一般是用来区分前端像后端的传输吧。。。
chendy
2020-12-03 13:43:22 +08:00
业务简单直接的话,用 entity 可以
业务复杂之后,业务 /展示 和 实体耦合一起有时候会比较难受,拆 dto 会舒服一些
IMCA1024
2020-12-03 13:53:31 +08:00
request 实体->DTO 实体->entity 实体->VO 实体->response 实体

目前我们转了很多层。。。
anakinsky
2020-12-03 13:54:50 +08:00
我们公司微服务内部调用的返回都是 entity,给前端的都是按需封装成 VO 返回
glacial
2020-12-03 14:17:22 +08:00
@comsweetcs 得看自已业务 这个没有强制要求 我不要弄那么多层 所以 只用 dto 就可以了
glacial
2020-12-03 14:18:02 +08:00
@IMCA1024 那你们 维护起来不是很 麻烦
ericgui
2020-12-03 14:20:23 +08:00
@IMCA1024 慢不?
idoggy
2020-12-03 14:20:58 +08:00
你底层 orm 怎么弄的,一张表一个 class 的就弄成 dto 自己用的时候再封装成 entity
liuch
2020-12-03 14:23:41 +08:00
取决于你的项目复杂度。复杂的项目有很多层,不是查库出来就能返回的,这种不只有 dto,vo
gaoli1992
2020-12-03 14:30:10 +08:00
规范角度来说不应该返回 entity 实体,逼近 entity 中包含主建、创建时间、更新时间等信息,而这些信息不应该让前端知悉的。
IMCA1024
2020-12-03 16:09:11 +08:00
@ericgui 慢倒是不慢 多层转换
IMCA1024
2020-12-03 16:11:04 +08:00
@glacial 确实是。但没办法 规定
Java,微服务
我们 Feign 接口打 client 包 接参 request 返回 response
controller 传到 service 用 DTO
mapper 返回 vo
comsweetcs
2020-12-03 16:35:59 +08:00
@glacial 可能你的业务比较简单吧.像很多 Model 里的字段,其实前端确实没必要字段,比如一些时间字段等。使用 VO 或者你爱咋叫都行,重点是把这部分信息屏蔽,一来可以做安全控制,二来减少网络传输数据量,三来传得更快。我们用的就是 jpa,转换有一套成熟的代码封装方案吧,单体用 BeanUtils,数组列表用 DozerMapper 吧,自己再封装下,也没多麻烦。。。
Cbdy
2020-12-03 16:37:20 +08:00
BuffDog
2020-12-04 09:29:07 +08:00
哎,这种场景,C#的匿名对象是真的香,虽然 java 使用 map 能实现类似的操作,但还是太麻烦了
Alex5467
2020-12-04 10:11:42 +08:00
entity 数据包含前端不需要的数据,而且也不全啊!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/731722

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX