详见 http://hi.baidu.com/xiaoduo170/item/0706735065d914dcd48bac5b
http://blog.csdn.net/alex197963/article/details/5319327
JSR-181的元数据清单
下面介绍JSR-181里面各个元数据的相关参数及用途
Annotation Retention Target Description
WebService Runtime Type
标注要暴露为Web Services的类或接口
WebParam Runtime Parameter 自定义服务方法参数到WSDL的映射
WebResult Runtime Method 自定义服务方法返回值到WSDL的映射
WebMethod Runtime Method 自定义单个服务方法到WSDL的映射
Oneway Runtime Method 必须与@WebMethod连用,表明被标注方法只有输入没有输出,这就要求被标注方法不能有返回值,也不能声明checked exception
HandlerChain Runtime Type,Method,Field 将Web服务与外部Handler chain关联起来
SOAPBinding Runtime Type,Method 自定义SOAPBinding
JSR-181元数据使用示例
package WebServices; import java.io.File; import java.io.IOException; import javax.jws.Oneway; import javax.jws.WebMethod; import javax.jws.WebParam; import javax.jws.WebResult; import javax.jws.WebService; import javax.xml.ws.Endpoint; /** * @author chinajash */ @WebService(targetNamespace="http://blog.csdn.net/chinajash",serviceName="HelloService") public class WSProvider { @WebResult(name="Greetings")//自定义该方法返回值在WSDL中相关的描述 @WebMethod public String sayHi(@WebParam(name="MyName") String name){ return "Hi,"+name; //@WebParam是自定义参数name在WSDL中相关的描述 } @Oneway //表明该服务方法是单向的,既没有返回值,也不应该声明检查异常 @WebMethod(action="printSystemTime",operationName="printSystemTime")//自定义该方法在WSDL中相关的描述 public void printTime(){ System.out.println(System.currentTimeMillis()); } public static void main(String[] args) { Thread wsPublisher = new Thread(new WSPublisher()); wsPublisher.start(); } private static class WSPublisher implements Runnable{ public void run() { //发布WSProvider到http://localhost:8888/chinajash/WSProvider这个地址,之前必须调用wsgen命令 //生成服务类WSProvider的支持类,命令如下: //wsgen -cp . WebServices.WSProvider Endpoint.publish("http://localhost:8888/chinajash/WSProvider",new WSProvider()); } } }
如果想看到Web Services Engine生成的WSDL文件是否遵守上面的元数据, 我们没有必要将上面的WSProvider部署到支持JSR-181的应用服务器或Servlet形式的Web Services Engine,现在JDK6已经提供了一个很简单的机制可以用来测试和发布Web Services,下面讲讲如何在JDK6环境下发布Web Services和查看生成的WSDL
1.将/bin加入path环境变量
2.在命令行下切换当前项目目录下,运行下面命令
wsgen -cp .\WebRoot\WEB-INF\classes -s .\src WebServices.WSProvider
在这个例子中会生成以下3个类的源代码文件及class文件
SayHi
SayHiResponse
PrintTime
3.执行如下代码发布WSProvider到http://localhost:8888/chinajash/WSProvider,在这里可以执行WSProvider类的main方法就可以
Endpoint.publish("http://localhost:8888/chinajash/WSProvider",new WSProvider());
4.在浏览器输入http://localhost:8888/chinajash/WSProvider?wsdl就可以看到生成的WSDL文件
切换到src目录下,用wsimport为服务消费者(也就是服务的客户端)生成必要的帮助类,命令如下:
wsimport -p WebServices.client -Xnocompile http://localhost:8888/chinajash/WSProvider?wsdl
这会在<当前目录>\WebServices\client\ 下生成客户端的帮助类,在这个例子中会生成7个类
HelloService.java
ObjectFactory.java
package-info.java
PrintSystemTime.java
SayHi.java
SayHiResponse.java
WSProvider.java
在客户端:
HelloService hs = new HelloService();
WSProvider ws = hs.getWSProviderPort();
System.out.println(ws.sayHi("chinajash"));
ws.printSystemTime();
调用上述代码后客户端控制台输出
hi,chinajash
服务端控制台输出服务器当前系统时间
wsgen
wsgen 是在JDK的bin目录下的一个exe文件(Windows版),该命 令的主要功能是用来生成合适的JAX-WS。它读取Web Service的终端类文件,同时生成所有用于发布Web Service所依赖的源代码文件和经过编译过的二进制类文件。这里要特别说明的是,通常在Web Service Bean中用到的异常类会另外生成一个描述Bean,如果Web Service Bean中的方法有申明抛出异常,这一步是必需的,否则服务器无法绑定该对像。此外,wsgen 还能辅助生成WSDL和相关的xsd文件。wsgen 从资源文件生成一个完整的操作列表并验证web service是否合法,可以完整发布。
命令参数说明:
- -cp 定义classpath
- -r 生成 bean的wsdl文件的存放目录
- -s 生成发布Web Service的源代码文件的存放目录(如果方法有抛出异常,则会生成该异常的描述类源文件)
- -d 生成发布Web Service的编译过的二进制类文件的存放目录(该异常的描述类的class文件)
-
命令范例: wsgen -cp ./bin -r ./wsdl -s ./src -d ./bin -wsdl org.jsoso.jws.server.Example
wsimport
wsimport也是在JDK的bin目录下的一个exe文件(Windows版),主要功能是根据服务端发布的wsdl文件生成客户端存根及框架,负责 与Web Service 服务器通信,并在将其封装成实例,客户端可以直接使用,就像使用本地实例一样。对Java而言,wsimport帮助程序员生存调用web service所需要的客户端类文件.java和.class。要提醒指出的是,wsimport可以用于非Java的服务器端,如:服务器端也许是C# 编写的web service,通过wsimport则生成Java的客户端实现。
命令参数说明:
- -d 生成客户端执行类的class文件的存放目录
- -s 生成客户端执行类的源文件的存放目录
- -p 定义生成类的包名
- -keep 继续生成文件,会同时生成class、java文件
- -Xnocompile 不编译生成的java文件,即不会生成class文件
-
命令范例: wsimport -d ./bin -s ./src -p org.jsoso.jws.client.ref -Xnocompile http://localhost:8080/hello?wsdl
相关推荐
本篇内容将详细讲解在JDK 5下使用Apache CXF开发Web服务客户端所需的核心jar包以及相关知识点。 1. **Apache CXF简介** Apache CXF是一个开源的Web服务框架,它整合了XFire和 Celtix两个项目,提供了全面的Web服务...
JDK 6引入了JAX-WS(Java API for XML Web Services),它是一个标准的、基于注解的框架,简化了Web Service的开发流程。以下是对标题和描述中涉及的知识点的详细说明: 1. **JAX-WS**: JAX-WS是Java平台的一个核心...
当我们谈论“JDK6开发Web服务”时,这意味着我们将探讨如何使用Java 6版本来创建和实现Web服务。Web服务是一种通过网络进行通信的应用程序,它允许不同系统之间的数据交换,通常基于SOAP(Simple Object Access ...
【如何使用Eclipse开发Web Service】 在开发Web Service时,Eclipse作为一个强大的集成开发环境(IDE),提供了便捷的工具和插件支持。本篇将详细阐述如何在Eclipse中进行Web Service的开发。 1. **准备工作** ...
【用Axis2开发Web Service】是本文的核心主题,轴心技术是Java开发Web服务的一种框架,相较于Axis1,其过程更为简洁。以下是关于使用Axis2开发Web Service的详细步骤和知识点: 1. **实验环境搭建**: - 首先确保...
在Java世界中,开发Web服务(WebService)是一种常见的数据交换方式,特别是在分布式系统和跨平台通信中。JDK6提供了对WebService的支持,使得开发者能够轻松地创建、发布和消费Web服务。本主题将深入探讨如何使用...
6. 将Web服务的WAR文件部署到Tomcat的`webapps`目录下,或者手动将服务相关的文件复制到Tomcat的`webapps`目录下的特定应用目录。 7. 启动Tomcat,通过浏览器访问Web服务的URL,验证服务是否正常工作。 通过以上...
基于AXIS2实现Web Service开发是一项常见的任务,尤其在企业级应用中,Web Service作为不同系统间通信的重要桥梁。AXIS2是Apache软件基金会提供的一个轻量级、高性能的Web Service框架,它提供了完整的Web Service...
在 JDK 1.6 版本中,注解的引入极大地简化了 Web 服务的开发,使得开发者能够更高效地创建、部署和管理 Web 服务。 `@WebService` 是 Java Web Services (JAX-WS) 中的一个核心注解,用于声明一个类或接口作为 Web ...
### 利用JBOSS开发WEB SERVICE:详细指南与实践 #### 核心知识点概览 本篇将深入探讨在JBoss应用服务器上构建Web Service的全面指南,涵盖从安装配置到开发、测试、安全及高级特性应用的全过程。重点包括JBossWS的...
在实际开发中,使用 JDK 开发 Web Service 需要创建 Java 工程,创建相应的包(服务端),然后创建接口和实现类,并使用@WebService 注解标注接口和实现类。使用 Axis2 框架开发 Web Service 需要使用 Axis2 的工具...
本项目展示了如何利用纯Java JDK6实现一个基本的Web服务,无需额外依赖如Apache CXF或Axis等专门的Web服务框架。下面将详细介绍这个过程中的关键知识点。 1. **JAX-WS (Java API for XML Web Services)**: JDK6开始...
【标题】: "Axis开发Web Service程序教程" 【描述】: "本文旨在引导读者通过AXIS框架体验Web服务的开发流程,适合已有Web服务基础的Java、XML开发者学习。" 【标签】: "axis webservice soap java" 【内容】: ...
2. **JAX-WS**(Java API for XML Web Services):JAX-WS是Java中用于构建Web服务的最新规范,JDK 1.6自带版本2.1。它提供了一种更简便的方式创建Web服务。底层依赖JAXB(Java Architecture for XML Binding),...
**使用JDK开发WebService** 在Java开发领域,WebService是一种基于开放标准(如SOAP、WSDL和UDDI)的通信协议,它允许不同系统之间进行数据交换,跨越各种平台和编程语言。本教程将深入讲解如何使用JDK(Java ...
构建阶段涉及开发Web服务,这可以是自顶向下或自底向上的过程。自顶向下是从服务描述文件开始,生成服务实现和部署描述文件;自底向上则是从服务实现出发,反向生成描述文件。部署阶段,服务提供者将Web服务发布到...
- **SEI(Service Endpoint Interface)**: 这是定义Web服务接口的地方,包含了服务提供的操作方法。 - **实现类**: 对SEI接口的具体实现,处理业务逻辑。 - **WSDL生成**: JAX-WS可以自动生成WSDL文件,描述服务...
【使用XFire+Spring构建Web Service】是一种高效且灵活的方法,尤其适合于那些希望利用Spring框架的优秀特性来开发Web Service应用的开发者。XFire是一个先进的Web Service框架,与Axis2并列为新一代的选择,因其...
标题中的“利用jdk web服务api实现,这里使用基于 SOAP message 的 Web 服务”指的是使用Java开发Web服务,特别是基于SOAP(Simple Object Access Protocol)的消息传递协议。SOAP是一种用于交换结构化和类型化信息...