作为CSDN JavaWebService的小斑竹,很久就想写一些关于JWS的基础文章,苦于公私繁忙,一直无心下笔,所以一拖再拖,今日看了我斑块下有网友问及关于Java调用WebService之问题,遂下决心写下此文以资共勉。 装备: JDK1.4.1_02,关于这方面的问题,没必要说了吧。^_^ Java Web Services Developer Pack 1.2 (http://java.sun.com/webservices/downloads/webservicespack.html) 我的JWSDP安装路径为E:\miniTool\jwsdp-1.2\,文章中直接使用,就不重声。 平台: Microsoft Windows 2000 [Version 5.00.2195]
全文以Google的WebService为例,它提供了一个开发包,http://www.google.com/apis/download.html,但是很多的WebService不会这样的,只是告诉你一个他们的WSDL(WebService Description Language)文件。但是这都没有本质的区别的,在Google的开发包中也包含这么一个文件GoogleSearch.wsdl。大多数的WebService客户端开发,知道了WSDL文件就已经可以了,但是Google呢还需要一个LicenseKey,因为只是测试用,所以这个限制了同一个账号一天只能够查询1000还是2000次,我忘记了,我申请了两个,在我这个C#的演示站点(http://63.210.240.215/rookieport/)就用到了这两个LicenseKey(随机使用),关于这个C#演示站点的介绍及源文件见http://www10.brinkster.com/rookieport/default.aspx。非常遗憾的是,这两个站点我都不能够更新了,世界上从来没有免费的午餐!!! 好了,这篇文章的主题是JavaWebService而不是C#WebService,做好准备工作之后,我们稍微分析下WSDL文件,这个文件主要是描述WebService具体使用到了哪些数据结构(types中描述),提供了哪些Web服务功能(operation中描述),以及该服务的访问地址(service中描述),关于WSDL这里不详述,找时间补上。在GoogleSearch.wsdl中,我们看到有一个doGoogleSearch的Operation,从名称上我们可以看出,这个方法应该是提供搜索服务的,前面有一段描述了doGoogleSearch调用的参数: <message name="doGoogleSearch"> <part name="key" type="xsd:string"/> <part name="q" type="xsd:string"/> <part name="start" type="xsd:int"/> <part name="maxResults" type="xsd:int"/> <part name="filter" type="xsd:boolean"/> <part name="restrict" type="xsd:string"/> <part name="safeSearch" type="xsd:boolean"/> <part name="lr" type="xsd:string"/> <part name="ie" type="xsd:string"/> <part name="oe" type="xsd:string"/> </message> 第一个参数就是LicenseKey,第二个参数是要查询的内容,第三个参数是起始结果页,对于多页的结果集合起翻页作用,第四个参数是定义每页最大记录数,后面的参数不是很重要了,其中lr是定义查找的语言类型,假如查找简体中文可以为lang_zh-CN,ie/oe是输入和输出的编码类型,缺省都为UTF-8。 再往后面我们看到关于doGoogleSearch的返回类型的描述: <message name="doGoogleSearchResponse"> <part name="return" type="typens:GoogleSearchResult"/> </message> type="typens:GoogleSearchResult"说明了数据类型的命名空间,我们查找GoogleSearchResult,可以看到他是个复合类型, <xsd:complexType name="GoogleSearchResult"> <xsd:all> <xsd:element name="documentFiltering" type="xsd:boolean"/> <xsd:element name="searchComments" type="xsd:string"/> <xsd:element name="estimatedTotalResultsCount" type="xsd:int"/> <xsd:element name="estimateIsExact" type="xsd:boolean"/> <xsd:element name="resultElements" type="typens:ResultElementArray"/> <xsd:element name="searchQuery" type="xsd:string"/> <xsd:element name="startIndex" type="xsd:int"/> <xsd:element name="endIndex" type="xsd:int"/> <xsd:element name="searchTips" type="xsd:string"/> <xsd:element name="directoryCategories" type="typens:DirectoryCategoryArray"/> <xsd:element name="searchTime" type="xsd:double"/> </xsd:all> </xsd:complexType>
这里面用xml语言描述了GoogleSearchResult的数据结构,type="xsd:XXX"的属性都是简单数据类型,还用到了两个复合类型ResultElementArray, DirectoryCategoryArray读者可以继续分析,这些数据类型,都会被JWS的解释转换工具生成相应的Java类。两个Array结尾的复合类型,在JWSDP1.1以前也是生成了一个相应的ArrayOfXXXXX的类,现在1.2做得比较好了,,直接映射到java的数组。
好了我们可以进入客户端开发的实际性操作的第一步了,首先我们需要编辑一个xml格式的config文件,形式如下: <?xml version="1.0" encoding="UTF-8"?> <configuration xmlns="http://java.sun.com/xml/ns/jax-rpc/ri/config"> <wsdl name="SearchService" location="GoogleSearch.wsdl" packageName="rook.searcher"/> </configuration> 这里面指明了WebService描述文件的位置,可以是本地的也可以是远程的。后面packageName说明了生成WebService客户端文件的包名。把这个文件放到GoogleAPI的目录下。 第二步,启动控制台,进入GoogleAPI的目录 C:\googleapi>dir/w Volume in drive C is WIN2K Volume Serial Number is 0B73-18E3
Directory of C:\googleapi
[.] [..] README.txt GoogleAPIDemo.java GoogleSearch.wsdl APIs_Reference.html LICENSE.txt googleapi.jar [javadoc] [dotnet] [soap-samples] [licenses] google.config JavaWebService客户端简明攻略.txt 建立一个client的目录C:\>mkdir client 执行WSCompile生成客户端文件C:\googleapi>E:\miniTool\jwsdp-1.2\jaxrpc\bin\wscompile -gen -d client -keep google.config -gen参数告诉编译器生成WebService客户端文件,-d client将生成的文件保存的目录,-keep指示保留中间文件。执行之后,进入client\rook\searcher目录可以看到生成系列java和java类文件。
第三步,我们创建客户端调用文件。查找包含rookie的中文网页前十条记录,然后打印标题和Url。 import rook.searcher.*; import java.rmi.*;
public class Searcher{ public static void main(String[] args){ try { GoogleSearchPort sport = new GoogleSearchService_Impl().getGoogleSearchPort(); GoogleSearchResult result = sport.doGoogleSearch("OyGtVqM5YRRS7hFXHLWEodMSEbiZlmc9", "rookie", 0, 10, true, "lang_zh-CN", true, "lang_zh-CN", "UTF-8", "UTF-8");//第一个参数是LicenseKey ResultElement[] results = result.getResultElements(); for ( int idx = 0; idx < results.length; idx ++) { System.out.println(idx + ": " + results[idx].getTitle() + "\r\n" + results[idx].getURL()); } } catch (Exception e) { e.printStackTrace(); } } }
第四步,编译。这里面用到了jaxrpc-impl包。 C:\googleapi\client>javac -classpath E:\miniTool\jwsdp-1.2\jaxrpc\lib\jaxrpc-impl.jar;. Searcher.java
第五步,执行。 C:\googleapi\client>java -cp E:\miniTool\jwsdp-1.2\jaxrpc\lib\jaxrpc-impl.jar;E:\miniTool\jwsdp-1.2\jaxrpc\lib\jaxrpc-api.jar;E:\miniTool\jwsdp-1.2\jwsdp-shared\lib\jax-qname.jar;E:\miniTool\jwsdp-1.2\jwsdp-shared\lib\activation.jar;E:\miniTool\jwsdp-1.2\jwsdp-shared\lib\mail.jar;E:\miniTool\jwsdp-1.2\jwsdp-shared\lib\xsdlib.jar;E:\miniTool\jwsdp-1.2\saaj\lib\saaj-api.jar;E:\miniTool\jwsdp-1.2\saaj\lib\saaj-impl.jar;E:\miniTool\jwsdp-1.2\jwsdp-shared\lib\commons-logging.jar;E:\miniTool\jwsdp-1.2\jaxp\lib\endorsed\xercesImpl.jar;E:\miniTool\jwsdp-1.2\jaxp\lib\endorsed\dom.jar;. Searcher
全文到此结束,讲了作JavaWebService客户端开发的基本步骤,希望能够抛砖引玉!文中不详之处,敬请指教:[email protected]

|