JDK6的新特性之十:Web服务元数据(Web Services metadata)

本文介绍JDK6中的Web服务元数据特性,通过对比.NET Framework中的实现方式,详细解释了Java EE 5中JSR-181规范如何使用元数据简化Web服务的开发流程,并提供了一个具体的示例。

JDK6的新特性之十:Web服务元数据(WebServicesmetadata)

.Net的WebServices元数据
早在.NetFramework1.0中,微软就用元数据功能(.net的attribute特性)来标注要暴露成WebService的方法,下面是用C#演示的利用.net的元数据功能暴露WebService方法的代码片断.
publicclassTestWS{
[WebMethod]
publicStringsayHi(){
return"Hi!";
}
publicintadd(intd1,intd2){
returnd1+d2;
}
}
上面的[WebMethod]是加在方法sayHi上面的元数据,用来告诉WebServices引擎(一般是ASP.NETRuntime),我这个方法需要暴露为一个WebService,你需要帮我生成相应的WSDL描述及相关支持文件.而另一个方法add没有加这个元数据,所以WebServices引擎就不会为该方法生成WSDL及相关支持文件

Java的WebServices元数据
Java里的Web服务元数据跟微软的方案基本没有语义上的区别,自从JDK5添加了元数据功能(Annotation)之后,SUN几乎重构了整个J2EE体系,由于变化很大,干脆将名字也重构为JavaEE,JavaEE(当前版本为5.0)将元数据纳入很多规范当中,这其中就包括WebServices的相关规范,加入元数据之后的WebServices服务器端编程模型就跟上面看到的C#片断差不多了,这显然比以前的JAX-RPC编程模型简单(当然,Axis的编程模型也很简单).这里要谈的Web服务元数据(JSR181)只是JavaWeb服务规范中的一个,它跟CommonAnnotations,JAXB2,StAX,SAAJ和JAX-WS等共同构成JavaEE5的WebServices技术堆栈.

JSR-181的元数据清单
下面介绍JSR-181里面各个元数据的相关参数及用途
AnnotationRetentionTargetDescription
WebServiceRuntimeType
标注要暴露为WebServices的类或接口
WebParamRuntimeParameter自定义服务方法参数到WSDL的映射
WebResultRuntimeMethod自定义服务方法返回值到WSDL的映射
WebMethodRuntimeMethod自定义单个服务方法到WSDL的映射
OnewayRuntimeMethod必须与@WebMethod连用,表明被标注方法只有输入没有输出,这就要求被标注方法不能有返回值,也不能声明checkedexception

HandlerChainRuntimeType,Method,Field将Web服务与外部Handlerchain关联起来
SOAPBindingRuntimeType,Method自定义SOAPBinding

JSR-181元数据使用示例

packageWebServices;

importjava.io.File;
importjava.io.IOException;
importjavax.jws.Oneway;
importjavax.jws.WebMethod;
importjavax.jws.WebParam;
importjavax.jws.WebResult;
importjavax.jws.WebService;
importjavax.xml.ws.Endpoint;

/**
*@authorchinajash
*/
@WebService(targetNamespace="http://blog.youkuaiyun.com/chinajash",serviceName="HelloService")
publicclassWSProvider{
@WebResult(name="Greetings")//自定义该方法返回值在WSDL中相关的描述
@WebMethod
publicStringsayHi(@WebParam(name="MyName")Stringname){
return"Hi,"+name;//@WebParam是自定义参数name在WSDL中相关的描述
}
@Oneway//表明该服务方法是单向的,既没有返回值,也不应该声明检查异常
@WebMethod(action="printSystemTime",operationName="printSystemTime")//自定义该方法在WSDL中相关的描述
publicvoidprintTime(){
System.out.println(System.currentTimeMillis());
}
publicstaticvoidmain(String[]args){
ThreadwsPublisher=newThread(newWSPublisher());
wsPublisher.start();
}
privatestaticclassWSPublisherimplementsRunnable{
publicvoidrun(){
//发布WSProvider到http://localhost:8888/chinajash/WSProvider这个地址,之前必须调用wsgen命令
//生成服务类WSProvider的支持类,命令如下:
//wsgen-cp.WebServices.WSProvider
Endpoint.publish("http://localhost:8888/chinajash/WSProvider",newWSProvider());
}
}
}

如果想看到WebServicesEngine生成的WSDL文件是否遵守上面的元数据,我们没有必要将上面的WSProvider部署到支持JSR-181的应用服务器或Servlet形式的WebServicesEngine,现在JDK6已经提供了一个很简单的机制可以用来测试和发布WebServices,下面讲讲如何在JDK6环境下发布WebServices和查看生成的WSDL
1.将<JDK_HOME>/bin加入path环境变量
2.在命令行下切换当前目录到WSProvider的class文件所在的目录,运行下面命令
wsgen-cp.WebServices.WSProvider
在这个例子中会生成以下3个类的源代码文件及class文件
SayHi
SayHiResponse
PrintTime
3.执行如下代码发布WSProvider到http://localhost:8888/chinajash/WSProvider,在这里可以执行WSProvider类的main方法就可以
Endpoint.publish("http://localhost:8888/chinajash/WSProvider",newWSProvider());
4.在浏览器输入http://localhost:8888/chinajash/WSProvider?wsdl就可以看到生成的WSDL文件,为了节省篇幅,这里就不把生成的WSDL文件贴上了,大家可以自己动手试试.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值