【发布时间】:2011-04-25 15:01:41
【问题描述】:
目前我们的软件正在通过 XML/SOAP 与远程 Web 服务进行交互。我们使用 XSD 来方便地创建要发送到远程系统的请求。这很好,而且运行良好。 XSD 非常棒。
但是,它确实会导致用于创建 Document 对象的代码块非常冗长。我想知道是否有人对处理这些大型代码块以创建请求和处理响应文档的良好设计实践有建议。
XSD Document 对象的意义在于将 XML 创建与客户端分离。但是,我认为外观类可能对每个服务都是一个好主意。我认为这对于创建来说非常有用,因为可以为外观类提供构建请求文档和发送请求的成分,而无需将客户端耦合到 XSD 类。我认为响应文档中出现了问题。如果有一个多级响应,您最终将创建 POJO 类只是为了包装 XSD 类,这似乎有点过头了。
【问题讨论】:
-
您没有使用 JAXB 有什么特别的原因吗? XJC 工具将为您创建 POJO 类...
-
@perp - 我是。 POJO 类“导致用于创建 Document 对象的代码块非常冗长。”
-
EclipseLink JAXB (MOXy) 实现有一个 XPath 映射扩展,可以减小代码块的大小:stackoverflow.com/questions/5779696/xsd-design-issues-in-java/…