WSDL 文档结构
WSDL 文档是利用这些主要的元素来描述某个 web service 的:
元素 |
定义 |
<portType> |
web service 执行的操作 |
<message> |
web service 使用的消息 |
<types> |
web service 使用的数据类型 |
<binding> |
web service 使用的通信协议 |
一个 WSDL 文档的主要结构是类似这样的:
<definitions>
<types>
definition of types........
</types>
<message>
definition of a message....
</message>
<portType>
definition of a port.......
</portType>
<binding>
definition of a binding....
</binding>
</definitions>
WSDL 文档可包含其它的元素,比如 extension 元素,以及一个 service 元素,此元素可把若干个 web services 的定义组合在一个单一的 WSDL 文档中。
如需完整的语法概述,请访问 WSDL 语法 这一节。
WSDL 端口
<portType> 元素是最重要的 WSDL 元素。
它可描述一个 web service、可被执行的操作,以及相关的消息。
可以把 <portType> 元素比作传统编程语言中的一个函数库(或一个模块、或一个类)。
WSDL 消息
<message> 元素定义一个操作的数据元素。
每个消息均由一个或多个部件组成。可以把这些部件比作传统编程语言中一个函数调用的参数。
WSDL types
<types> 元素定义 web service 使用的数据类型。
为了最大程度的平台中立性,WSDL 使用 XML Schema 语法来定义数据类型。
WSDL Bindings
<binding> 元素为每个端口定义消息格式和协议细节。
WSDL 实例
这是某个 WSDL 文档的简化的片段:
<message name="getTermRequest">
<part name="term" type="xs:string"/>
</message>
<message name="getTermResponse">
<part name="value" type="xs:string"/>
</message>
<portType name="glossaryTerms">
<operation name="getTerm">
<input message="getTermRequest"/>
<output message="getTermResponse"/>
</operation>
</portType>
在这个例子中,<portType> 元素把 "glossaryTerms" 定义为某个端口的名称,把 "getTerm" 定义为某个操作的名称。
操作 "getTerm" 拥有一个名为 "getTermRequest" 的输入消息,以及一个名为 "getTermResponse" 的输出消息。
<message> 元素可定义每个消息的部件,以及相关联的数据类型。
对比传统的编程,glossaryTerms 是一个函数库,而 "getTerm" 是带有输入参数 "getTermRequest" 和返回参数 getTermResponse 的一个函数。
HTA全称HTML Application,直接将HTML保存成HTA的格式,就是一个独立的应用软件,参见http://msdn.microsoft.com/zh-cn/library/ms536496(en-us).aspx
今天根据工作的需要,准备把原来的Subversion迁移到新的服务器上。
首先下载最新版的Subversion和Apache安装文件。Subversion下载的是压缩包,把它解压到C:\Program Files\Subversion下面。Apache下载的是msi安装文件(注意:Apache 2.2.x版的不支持Subversion),在安装的时候,提示可能因为Windows Installer的原因而安装失败,初步Google了一下,说要在注册表卸载后,再在安全模式下重新安装,因为是远程操作,而且服务器不是本人管理,因此放弃了Apache的安装,而是把原来可用的Apache复制到服务器上,至此初步完成了软件的安装。(事后同事说,Windows Installer好像直接再安装一次就可以了,不用进入安全模式,—_—!)接下来就进行软件的配置和代码库的迁移了:
1、把LANG=zh_CN.UTF8和APR_ICONV_PATH=C:\Program Files\Subversion\iconv这两个环境变量设置好,使得在运行Subversion命令是可以看到中文提示。
2、用svnadmin dump d:\svn\xxx > dumpfile命令导出xxx项目的Subversion库,然后再新的服务器上用先用svnadmin create d:\svn\xxx创建一个新的同名的库,再用svnadmin load d:\svn\xxx < dumpfile命令把刚才导出的文件导入到新的Subversion库中
3、修改Apache的配置文件,加入Subversion的mod_dav_svn.so和mod_authz_svn.so模块,并加入代码库的配置:
<Location /xxx>
DAV svn
SVNPath D:\svn\xxx
SVNAutoversioning on
#DAVGenericLockDB logs/repos-locks
AuthzSVNAccessFile D:\svn\conf\xxx.access
AuthType Basic
AuthName "身份验证"
AuthUserFile D:\svn\conf\passwd
Require valid-user
</Location>
4、重启Apache,在浏览器输入
http://localhost/xxx,并输入帐号密码,即可正常访问代码库
5、运行apache.exe -k intsall命令把Apache设为Windows的服务
至此,Subversion的迁移基本完成。
今天终于找到了ActionScript 3 Cookbook。需要的朋友可以去www.itpub.net下载。
今天尝试了一下安装Trac以配合Subversion,稍后打算在此基础上尝试一下持续集成。整个安装的过程基本顺利,途中遇到了两个小问题,也顺利解决了。在这里把这两个问题记下来,以备不时之需。问题如下:
1、根据apache的配置运行
http://localhost/cgi-bin/trac.cgi报404错误。通过把文件C:\Python23\share\trac\cgi-bin\trac.cgi复制到apache的cgi-bin目录,得到了解决。
2、在执行Trac的Browse Source或者其他功能时,报ImportError: DLL load failed 找不到相关的模块。通过把Subversion的bin目录下的DLL复制到apache的cig-bin目录,终于可以正常使用
另外,使用的过程中,Trac打开页面的速度比较慢。
Trac安装的相关参考:
http://blog.nona.name/archives/136.html http://trac.prelude-ids.org/trac.cgi/wiki/TracOnWindows