gpt4 book ai didi

java - 用于Rich Client Java(Swing)应用程序的持久性Web服务

转载 作者:搜寻专家 更新时间:2023-11-01 03:44:47 26 4
gpt4 key购买 nike

我正在使用Netbeans RCP富客户端将客户端服务器富客户端数据库应用程序(Swing)重写为三层应用程序。

默认情况下, Hibernate和其他 JPA 提供程序只能通过富客户端从非常繁琐的方式使用(本机数据库连接不穿越防火墙,松散延迟加载,管理Session / EntityManager生命周期的概念性问题...等其他问题)。因此,需要某种扩展才能在富客户中舒适地使用它们。

通常,富客户端在业务逻辑层(在服务器上)中调用 Web服务。通常,专用 Web服务方法处理每种对象类型的 CRUD 操作。
现在,我不想来为我的应用程序的每个持久性类的的CRUD操作编写一个定制的Web服务,因此我认为对于此类操作可能存在一个通用持久性Web服务至少可以处理应用程序的所有 CRUD操作

有这样的持久性服务吗???

以下是我的想法/要求的详细信息:

该服务应该与 JPA注释的POJO 一起使用,因此它应该在服务器上使用某种JPA持久性提供程序。目前,我正在使用Hibernate,因此,如果它积极支持Hibernate,那将是一个加分。当然,POJO类必须包含在服务器端JPA配置中,我不希望处理未知POJO的任何种类。

我不想创建单独的值对象或数据传输对象,以在服务的客户端和服务器部分之间发送数据。我只想将传递给,只使用的JPA注释POJO 。我相信这是当今的标准做法。

客户端应接收数据并使用 HTTP请求将数据发送到服务的服务器端,以减少防火墙通信问题。 HTTP 代理的用法应该是可配置的。

持久性服务的客户端可以获取其执行的 JPA QL查询的POJO列表结果(作为简单的查询字符串发送,(可选,也可以在请求中发送名为**参数**))。这些查询以 Web服务调用或简单HTTP请求的形式从客户端发送到 Servlet。 如果可以在一个请求中发送多个JPA查询,那就太好了。客户端以POJO列表的形式接收请求的结果,这些POJO可能具有延迟加载的集合和对象引用(这些不是在查询时从服务器发送的)。

当客户端应用程序访问POJO中的延迟加载属性时,持久性服务的客户端应该能够自动/透明地完成请求请求。初始查询)。因此,在POJO已传输到客户端之后,透明的延迟加载应该保持工作

新的,更新的/脏的或要删除的POJO可以由持久性服务的客户端
发送到服务器,服务器上的更改保持不变并且成功/失败状态被发回(例如,给定的ID到新保存的POJO)。一个请求中可以发送多个要保存的POJO。

它应该具有标记事务边界的机制,以便可以在一个数据库事务中执行多个独立的HTTP服务调用(保留诸如Session / EntityManager之类的功能。 beginTransaction(),commit()和rollback())。

如果可以将验证访问控制检查插入服务器组件,那就太好了。

有这样的持久性服务项目吗???
可能是JPA持久性提供程序附带的扩展?

最佳答案

当我在2002年设计类似的应用程序时,我们四处搜寻要使用的框架,但最终不得不运行我们自己的框架。
通过将持久对象的子图转换为DTO(DataTransferObjects)对象,可以将持久对象的子图传输到Swing客户端,该对象维护属性映射和信息(如果客户端正在弄脏属性)。在返回服务器的途中,trx中仅更新了脏的属性。

您可能要使用JDO 2.0作为持久层。它支持从持久性对象图中分离对象或子树,通过电线发送那些分离的对象,并在以后的事务中重新附加它们。

但是,您将无法最大限度地减少通过网络发送的数据。

到目前为止最好的选择:运行您自己的机制,并将createDTO和updateFromDTO方法添加到您的持久对象中,但是我很高兴被证明是错误的。

关于java - 用于Rich Client Java(Swing)应用程序的持久性Web服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4488732/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com