栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

是否应该将实体转换为Repository对象内的DTO并将其返回到服务层?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

是否应该将实体转换为Repository对象内的DTO并将其返回到服务层?

在您发表评论后,现在更加清楚。让我们再试一次:

首先,进行一些澄清:

RestaurantOwnerRepository
实现存储库模式。带
@Entity
注释的对象是休眠实体,也是DAO代理。您
RestaurantOwnerService
是GWT服务,该服务只能返回与客户端和服务器共享的DTO。

因此,在非常简单的服务器端设置中 ,您具有一个DB-Backend,可以通过hibernate作为持久层访问数据,而通过服务层作为rest-
service。在这种设置中,您的休眠实体在整个服务器端代码之间共享。例如,您的服务层正在将实体转换为json格式。好吗

您的“高级”设置

  • 持久层
    • 与Hibernate(传递@Entity注释的对象)
    • 也许还有其他东西
  • 信息库层(不清楚要返回什么)
  • 服务层(GWT Servlet,提供与客户端共享的DTO)

Repository-Layer的定义:
在我看来,它是针对不同数据/持久层的抽象。它不提供业务逻辑,这更多的是进一步业务层的目的。业务层将上层的输出汇总在一起,进行计算并返回结果。但是根据您的评论来看,您的存储库层也可能是这种情况。但是我们可以澄清。

您的问题: 是否可以从存储库层返回DTO对象?

答: 不,从“存储库”层返回DTO并不是真的可以。

原因:
1.您的DTO是一个域实体,已转换为可以发送到客户端的格式。它有局限性,因此不能在其中使用某些服务器端库。2.考虑您还想提供其他服务层的情况。也许是一个REST接口,也许是另一个GUI框架。它们对于转移域实体都有各自的限制。您是否真的要为每个服务层复制存储库层?3.考虑要扩展存储库/业务层以使其使用的输出的情况

RestaurantOwnerRepository
。您真的要在那里工作DTO吗?

这就是为什么创建DTO是服务层的目的。因此,DTO在客户端和您的服务层之间共享。同样,您需要在服务层和存储库层之间共享的对象。我称这些领域实体。这些从存储库层返回并由服务层使用。再次在存储库层和持久性层之间相同。例如,持久层返回在存储层上使用的Hibernate实体。

在大多数情况下,可以从多层向下传播对象。因此,您可以将休眠实体从存储库层返回到服务层。较新版本的GWT甚至允许通过特殊设置在客户端使用JPA实体。因此,您的服务层可以进一步返回您的持久性实体。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/419335.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号