目前需要用到jax-ws,所以在进行学习,当前给出一个jax-ws的应用流程:
1.创建接口HelloWorldService接口及方法
/** * @(#) IHelloService.java */ package com.webservice; import javax.jws.WebMethod; import javax.jws.WebParam; import javax.jws.WebService; import javax.jws.soap.SOAPBinding; import javax.jws.soap.SOAPBinding.Style; /** * @version 1.0 * @Function 类功能说明:创建服务端接口 */ @WebService @SOAPBinding(style = Style.DOCUMENT) public interface IHelloWorldService { @WebMethod public String sayHelloWorld(@WebParam(name= "name")String name); }
2.创建接口的实现类,并为接口注入@WebService
/** * @(#) HelloWorldImpl.java */ package com.webservice; import javax.jws.WebService; /** * @version 1.0 * @Function 类功能说明:实现接口,并注入webservice注解 */ @WebService(endpointInterface = "com.webservice.IHelloWorldService") public class HelloWorldServiceImpl implements IHelloWorldService{ public String sayHelloWorld(String name) { return "Hello World : "+name; } }
3.编写发布类,通过Endpoint将接口发布出去
/** * @(#) WsPublisher.java */ package com.webservice; import javax.xml.ws.Endpoint; /** * @version 1.0 * @Function 类功能说明:发布服务端的接口 */ public class WsPublisher { public static void main(String[] args) { System.out.println("开始发布。。。"); Endpoint.publish("http://127.0.0.1:8012/hello_world", new HelloWorldServiceImpl()); System.out.println("发布成功。。。"); } }
运行WsPublisher后,有以下的效果:
开始发布。。。 2013-8-31 9:24:30 com.sun.xml.internal.ws.model.RuntimeModeler getRequestWrapperClass 信息: Dynamically creating request wrapper Class com.webservice.jaxws.SayHelloWorld 2013-8-31 9:24:30 com.sun.xml.internal.ws.model.RuntimeModeler getResponseWrapperClass 信息: Dynamically creating response wrapper bean Class com.webservice.jaxws.SayHelloWorldResponse 发布成功。。。
这时候就可打开浏览器查看http://127.0.0.1:8012/hello_world?wsdl 有如下效果说明发布成功了
<!-- Published by JAX-WS RI at http://jax-ws.dev.java.net. RI's version is JAX-WS RI 2.1.6 in JDK 6. --> <!-- Generated by JAX-WS RI at http://jax-ws.dev.java.net. RI's version is JAX-WS RI 2.1.6 in JDK 6. --> <definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tns="http://webservice.com/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://schemas.xmlsoap.org/wsdl/" targetNamespace="http://webservice.com/" name="HelloWorldServiceImplService"> <types> <xsd:schema> <xsd:import namespace="http://webservice.com/" schemaLocation="http://127.0.0.1:8012/hello_world?xsd=1"/> </xsd:schema> </types> <message name="sayHelloWorld"> <part name="parameters" element="tns:sayHelloWorld"/> </message> <message name="sayHelloWorldResponse"> <part name="parameters" element="tns:sayHelloWorldResponse"/> </message> <portType name="IHelloWorldService"> <operation name="sayHelloWorld"> <input message="tns:sayHelloWorld"/> <output message="tns:sayHelloWorldResponse"/> </operation> </portType> <binding name="HelloWorldServiceImplPortBinding" type="tns:IHelloWorldService"> <soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document"/> <operation name="sayHelloWorld"> <soap:operation soapAction=""/> <input> <soap:body use="literal"/> </input> <output> <soap:body use="literal"/> </output> </operation> </binding> <service name="HelloWorldServiceImplService"> <port name="HelloWorldServiceImplPort" binding="tns:HelloWorldServiceImplPortBinding"> <soap:address location="http://127.0.0.1:8012/hello_world"/> </port> </service> </definitions>
4.创建相关的文件夹,在cmd命令行下,使用wsgen指令,生成相应的wsdl文件和异常处理的相关类 wsgen -cp .;bin/ -r ws/wsdl -s ws/src -d ws/bin -wsdl com.webservice.HelloWorldServiceImpl (没办法上传图片确实比较坑)
5.创建相关的文件夹,使用wsimport指令生成客户端代码
wsimport -s client/src -d client/bin -p com.webservice.client http://localhost:8012/hello_world?wsdl
生成相应的接口:
com.webservice.client.HelloWorldServiceImplService com.webservice.client.IHelloWorldService com.webservice.client.ObjectFactory com.webservice.client.package-info com.webservice.client.SayHelloWorld com.webservice.client.SayHelloWorldResponse
6.最后就可以写客户端代码,进行调用了。
/** * @(#) HelloWorldClient.java */ package com.webservice.client.test; import com.webservice.client.HelloWorldServiceImplService; import com.webservice.client.IHelloWorldService; /** * @version 1.0 * @Function 类功能说明:客户端调用 */ public class HelloWorldClient { public static void main(String[] args) { HelloWorldServiceImplService service = new HelloWorldServiceImplService(); IHelloWorldService worldService = service.getHelloWorldServiceImplPort(); System.out.println(worldService.sayHelloWorld("hahaha")); } }
运行客户端输出结果:
Hello World : hahaha
到这里整个流程也就跑完了,现在是刚开始学习webservice的jax-ws;以后还需要继续深入学习,内容会有一定的更新
相关推荐
【Java WebService Jax-WS 创建】是Java中创建Web服务的一种常见方式,主要用于构建基于SOAP(Simple Object Access Protocol)的Web服务。JAX-WS(Java API for XML Web Services)是Java EE 5及更高版本中提供的...
读者可以通过阅读该博客文章深入了解JAX-WS的实践应用。 综上所述,JAX-WS是Java平台上的Web服务标准,它通过注解驱动的模型和XML配置方式,简化了Web服务的开发和调用。与JAXB结合使用,能够高效地处理数据交换,...
在Java应用服务器,如Tomcat中使用JAX-WS时,通常需要一些特定的JAR文件来支持其功能。这些JAR文件包含了JAX-WS的运行时库和相关的服务实现。描述中提到的"Jax-ws所需要的JAR包"很可能包括了以下几个关键组件: 1. ...
本篇将深入讲解如何基于JAX-WS开发一个WebService实例。 首先,让我们了解JAX-WS的基本概念。JAX-WS提供了一种简单的方式来创建SOAP(Simple Object Access Protocol)Web服务,它集成了Java SE和Java EE平台,使得...
- **JAX-WS运行时环境**:Java EE应用服务器(如Tomcat、Glassfish、WildFly等)内置了JAX-WS支持,可以自动处理服务的生命周期,包括服务的发布、查找和取消发布。 4. **优势:** - **简单性**:JAX-WS使用注解...
基于jax-ws 实现的web service client和server端的demo程序。 注:如果使用的是 myeclipse 时 server 部署到tomcat 启动的时候会报错 解决办法:找到myeclipse安装目录下的 plugins 目录里 查找 webservices-rt.jar,...
MyEclipse8_0中使用 JAX-WS 部署 WebService 实例 - 外衣 - 博客频道 - CSDN_NET.mht
Java 基于第三方插件实现WebService实在麻烦,尤其是要添加几十M的Jar包...还好,自从JDK 1.6开始,Java自身已经支持WebSeervice的开发即JAX-WS,附件是一个简单的示例,供入门参考。注意,JDK环境要求1.6及以上版本。
在这个"jax-ws webservice简单demo"中,我们将探讨JAX-WS的基础知识、如何创建一个简单的Web服务以及如何测试这个服务。 首先,JAX-WS的核心组件包括: 1. **Service端点接口(SEI, Service Endpoint Interface)**...
**Java API for XML Web ...在"HelloServer"这个示例中,我们可以看到一个基本的JAX-WS服务端实现,它演示了如何发布一个简单的"Hello, World"服务。通过学习和实践,你将能够构建更复杂、功能丰富的Web服务应用。
1. **企业级应用集成:**JAX-WS常用于构建企业级系统之间的集成,通过Web服务实现不同系统间的通信。 2. **跨平台通信:**由于SOAP是一种开放的标准,JAX-WS使得Java应用能够与其他平台(如.NET或PHP)上的应用进行...
JAX-WS使得开发人员能够通过简单的接口定义和注解来构建Web服务,从而简化了Web服务的开发过程。与早期的Java API for XML Processing (JAX-RPC)相比,JAX-WS更符合面向对象的设计原则,更易于使用。 在本示例中,...
Java API for XML Web Services(JAX-WS)是Java平台上的一个标准,用于构建和部署Web服务。它简化了Web服务的开发,使得Java开发者能够更方便地创建、调用和部署SOAP(Simple Object Access Protocol)服务。在这个...
JAX-WS 2.2 RI 所包含的JAR包集合,包含25个JAR包,列表如下: FastInoset.jar gmbal-api-only.jar ha-api.jar javax.annotation.jar javax.mail_1.4.jar jaxb-api.jar jaxb-impl.jar jaxb-xjc.jar jaxws-api...
“metro-jax-ws-jaxws221x.zip”是一个宝贵的资源,对于想要学习和掌握JAX-WS的开发者来说,它可以提供一个完整的实践环境,帮助理解Web服务的生命周期、客户端和服务端的交互以及如何在实际项目中应用JAX-WS技术。...
在实际应用中,JAX-WS还支持WSDL(Web Services Description Language)用于定义Web服务的接口和绑定。WSDL文件是XML格式的,它描述了服务的输入、输出、操作以及如何访问这些服务。开发者可以利用JAX-WS的工具自动...
JAX-WS方式开发和部署webservice应用,JAX-WS方式开发和部署webservice应用,JAX-WS方式开发和部署webservice应用,JAX-WS方式开发和部署webservice应用,JAX-WS方式开发和部署webservice应用
**标签:“jax-ws2.1”**表明这个压缩包与JAX-WS 2.1规范相关,该规范发布于2006年,是JAX-WS的早期版本,相对于后续的2.2及更高版本,可能会缺少一些特性或改进,但仍然广泛应用于许多现有的Java EE项目中。...
- **添加注解**:在服务接口和实现类上添加必要的JAX-WS注解,例如`@WebService`和`@WebMethod`等,用以指导工具生成相应的WSDL文件和其他元数据。 3. **示例:订单处理Web服务** - **服务接口定义**:创建一个...
使用 Eclipse JavaEE 开发 WebService 时,若选择手动创建原生的JAX-WS服务,需要导入此jar资源(教程详见我的博文https://blog.csdn.net/weixin_50604409/article/details/116399530)。 如果您同时装有 IntelliJ ...