- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我们正在使用 AngularJS、Rest、JPA 开发 Web 应用程序。我已经阅读了一些关于域实体不应通过服务公开的文章。我知道这是紧密耦合,可能存在循环引用、关注点分离,这对我来说似乎是有效的。但后来我看到有关将 jpa 和 jaxb 映射应用于同一模型的文章,eclipseLink moxy 就是一个例子。
然后是 Spring data REST,它通过 rest api 公开 jpa 实体。(可能是 Spring Data REST 用于解决手头的不同问题)
所以我有点困惑。回答以下 2 个问题和其中一个比另一个更好的场景会有所帮助。
将 jaxb 和 JPA 注释应用到同一个领域模型有什么好处?这样做主要是为了避免中间出现 DTO层?
是否应该仅在开发需要公开 CRUD 操作并且实际上不涉及其他业务功能的应用程序时才使用 Spring data REST?
最佳答案
使用 DTO 需要一定的开销:必须创建 DTO 类;实体类必须在序列化之前映射到 DTO。
DTO 也“感觉不对”,因为它们似乎违反了“不要重复自己”的原则。查看一个实体和一个 DTO 并发现它们本质上相同是令人沮丧的。
因此,直接公开您的 JPA 实体可以减少代码并减少使用代码时的精神开销。您的 Controller 、服务和存储库都处理相同的类。
但是有一些问题:
您的内部表示与您要向 API 用户公开的界面不匹配。
真实示例:根文档是 article
,子文档是 sections
的分层文档。在内部,每个文档都与可能为空的父文档有关系。
直接通过 REST 接口(interface)公开此实体需要客户端发送 id
(或 HATEOAS 中的 url
)作为其提交实体的一部分以正确链接在一起文件。
更好的方法是在创建子部分时让 api 用户 POST 到 /articles/{id}/sections/
。
公开内部数据。
您的实体可能包括标识符、磁盘上的路径等,它们并非真正供公众使用。在序列化时,您必须 @JsonIgnore
这些。反序列化时,您还需要手动从实体中填充这些内容。
性能。
与上面的点类似;也许您的实体包含一个大数据对象。您希望用户能够 POST 或 PUT 这些,但不应该要求他们下载对象只是为了阅读实体的其他字段。
潜在的序列化问题。
惰性加载集合是这里的典型失败案例。
比必要的更复杂的序列化表示。
现实世界的例子:一个词
实体,带有一组同义词
;同义词取决于单词。直接序列化实体将导致:
{ "id":12,
"word": "cat",
"synonyms": [
{ "id": 23,
"synonym": "kitty"
},
{ "id": 34,
"synonym": "pussycat"
}
]
}
更好的模型是:
{ "word": "cat",
"synonyms": [
"kitty",
"pussycat"
]
}
同一类上有很多注释,这会降低清晰度。
根据实体的复杂性,您可能有 JPA 注释(@Entity
、@Id
、@GeneratedValue
、@Column
、@ManyToMany
、@MappedBy
等)、XML 注释(@XmlRootElement
、@XmlType
、@XmlElement
等)、JSON 注释(@JsonInclude
、@JsonIgnore
、@JsonProperty
等)、和验证注释(@NotNull
、@Null
等)都在同一个类上。
由于所有这些问题,我通常使用 DTO。我手动将实体映射到 DTO,但有些项目试图让这更容易,比如 Dozer .
我可以想象使用 spring-data-rest
或直接暴露我的实体只有在我有非常简单的实体,它们之间没有太多关系,并且它们之间有很高的对应关系的情况下实体模型和我希望向用户公开的模型。
关于java - 通过服务公开 JPA 实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29630162/
例如 Form1 frm1 = new Form1(); TextBox tb = new TextBox(); frm1.Controls.Add(tb); 现在我不能说 f
我有一个日期过滤器,我已经在我的 View 中公开了它。我想让界面更加用户友好并加强它的外观。我不想选择日期,而是从以下选项中进行选择。 最后一天 上周 去年 全部 然后,这将过滤日期字段。这可能吗?
如何向用户公开我的用户控件组件之一的 ActualWidth 属性? 我找到了很多关于如何通过创建新的依赖属性和绑定(bind)来公开普通属性的示例,但没有关于如何公开像 ActualWidth 这样
Github 最近推出了项目功能。 当项目处于 repo 级别时,如果 repo 本身是公开的,那么任何人都可以访问这些项目。 但是,组织级别的项目仅对组织成员可见。 例如,https://githu
我想要从我的网络服务器访问 JavaScript 文件。 以便任何人都可以在其网站中访问和引用它。 e-g 假设 abcxyzserver.com 是我的网络服务器。 www.abcxyzserv
尝试使用curl命令上传到blob存储 curl --upload-file --url "https://.blob.core.windows.net//" 但不断收到“HTTP/1.1 404
我正在尝试获取 Canvas 的上下文,显然我收到错误Uncaught TypeError: Cannot call method 'getContext' of null 显然我在它初始化之前就得到
我正在对设置 HA 集群的解决方案进行故障排除。虽然我知道应用程序执行故障转移和故障回复所需的端口,但不知何故 dockerized 解决方案不起作用。我怀疑有一些我还不知道的端口。 目前,我的 EX
我试图在能够使用 Helm 运行的k8集群中设置Prometheus。当我使用外部IP将Prometheus-Server作为LoadBalancer服务公开时,访问仪表板。 当我尝试将此服务配置为C
我知道关于这个主题也有类似的问题,但我不完全确定他们正在解决同样的问题。所以要明确的是... 我有一个现有的类库,其中包含用于类型、业务逻辑和数据访问的命名空间。逻辑和数据访问命名空间中的类是静态的,
尝试使用curl命令上传到blob存储 curl --upload-file --url "https://.blob.core.windows.net//" 但不断收到“HTTP/1.1 404
1.)执行以下命令生成一个随机数,用于后面的步骤 NUMBER=$[ ( $RANDOM % 1000 ) + 1 ] echo $NUMBER 注意:将句子 your random number 替
类似这样的问题有很多,但仍然无法得到我真正想要的,而且它们都有一些与我不同的地方,那就是:我有一个 UserControl: 在名为UCProject 的类库项目中单独构建; UCProject 项目
我有一个这样的基类: public class BaseModalCommand { protected object m_commandArgument; protected i
给定以下 JQuery 插件。是否可以将变量“元素”公开给插件外部的 javascript?如果是这样,这是怎么做到的?对于此插件外部的 javascript,访问“元素”的语法是什么? (funct
我有两个使用 jhipster 创建的微服务。 (ms1 和 ms2) 我使用 AuthorizedFeignClient 在两个微服务之间进行通信。 ms1 有一些 DTO 类,用作 REST AP
我正在使用错误跟踪软件来报告网络浏览器中发生的任何错误,但我的生产站点上的代码已缩小。因此,调试几乎是不可能的(变量名被更改等)。 我想将完整的源映射文件投入生产,以便我可以调试这些错误,但在这样做时
我在 Kotlin 公开库中可以找到的所有 Material 都假定该表具有一个主标识列,因此在大多数示例中显示的实体继承了 IntEntity 抽象类。例如: class UserLocation(
我有一个类 (Capsule),它有很多 protected 方法 (30+)。这个想法是允许开发人员扩展此类并在类 (ImADev) 中使用 protected 方法,但将其留给开发人员将它们公开为
Tomcat 日志位置是: /apache/apache-tomcat-8.0.15/logs 允许通过浏览器访问这些日志的标准方法是什么? 为此启用 Tomcat 目录列表标准吗? 最佳答案 我曾在
我是一名优秀的程序员,十分优秀!