Java Web服务: Metro简介 - 编程入门网
两种技巧,不需要将 Metro webservices-api.jar 包括在服务 WAR 文件中,因为它在 Web 服务器的类路径中是直接可用的。
构建和运行示例代码 在运行示例代码之前,首先需要下载和安装当前版本的 Metro(代码经过 1.5 版的测试)。另外还需 要对解压的示例代码下载文件根目录中的 build.properties 文件进行编辑,将 metro-home 属性的值改 为 Metro 安装目录的路径。如果要使用不同的系统或端口上的服务器进行测试,那么可能需要更改 host-name 和 host-port。 要使用 Ant build.xml 构建示例应用程序,打开一个控制台,进入下载文件的根目录,输入 ant。这 将首先调用 JAX-WS wsimport 工具(包括在 Metro 中),然后编译客户端和服务器,最后将服务器代码 打包为 WAR。接着可以将生成的 metro-library.war 文件部署到测试服务器,并在在控制台输入 ant run,尝试运行示例客户端。示例客户端运行,经过一系列对服务器的请求,打印出每个请求的简要结果 。 不幸的是,Metro 处理不会完全地执行例子。当 Metro 服务器代码将异常转换成 SOAP Fault 消息时 ,它还(默认地)发送栈跟踪细节。Metro 客户端代码不能识别响应中的 Fault 数据,只是抛出适当的 Fault 对象,而不会填充包含的数据。在例子代码中,这会导致一个 NullPointerException。 为了改变这种令人惊讶的默认行为,需要在服务器 JVM 上设置一个 com.sun.xml.ws.fault.SOAPFaultBuilder.disableCaptureStackTrace=false 属性。(是的,正是这样 — 将 disableCaptureStackTrace 属性设为 false,以禁止发送栈跟踪)。通常需要在 Java Web 服务 器启动时进行这样的属性设置。对于 Tomcat,可以通过定义一个环境变量来完成这项工作:
对服务器配置进行了更改并且重新启动服务器后,应该可以完全运行示例程序。 结束语 在本文中,您看到了使用 Metro Web 服务栈的基本知识。由于 Metro 使用 JAX-WS 2.x 注释进行配 置,因此 “Axis2 中的 JAXB 和 JAX-WS” 中使用的 JAX-WS 2.x 示例应用程序代码在 Metro 中也可以 使用。唯一需要关心的是如何打包代码并将其部署到服务器端,Metro 和 Axis2 在这方面有明显的差异 。Metro 使用嵌入式方法为每个服务或服务组创建一个 Web 应用程序(不提供控制或监视功能)。而 Axis2 通常使用一个专用的 Web 应用程序作为任意数量的服务的宿主(通过 Web 页面直接提供基本的控 制和监视功能)。 除了基本的 Web 服务消息交换外,Metro 还支持 SOAP 扩展,例如 WS-Security。和服务打包问题一 样,Metro 和 Axis2 对这方面的相似问题采取不同的方法。在下一篇文章中,您将看到 Metro 如何处理 在前面的文章中使用 Axis2 处理的 WS-Security 例子。 本文配套源码 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |