第十五章 创建Web客户端 - 类包名称的 SOAP 向导规则

2024-06-02  本文已影响0人  Cache技术分享

第十五章 创建Web客户端 - 类包名称的 SOAP 向导规则

类包名称的 SOAP 向导规则

SOAP 向导对类包名称应用以下规则:

默认情况下,类名称是 Web 客户端或服务名称,并附加 Config。如果为配置子包指定一个值,则生成的类与 Web 客户端或服务具有相同的名称(但位于给定的子包中)。

可以选择编辑这些包名称。

并非所有名称空间都必须对应于生成的类。例如,本示例中使用的 WSDL 使用命名空间 https://schemas.xmlsoap.org/wsdl、https://schemas.xmlsoap.org/wsdl/mimehttps://schemas.xmlsoap.org/wsdl 。在这种情况下,这些命名空间中没有生成的类,并且不会生成相应的包。

以编程方式生成客户端类

可以使用 %SOAP.WSDL.Reader 类以编程方式生成客户端类。

生成的类及其组织可能与使用 SOAP 向导时不同,后者提供了对生成类的包的更好控制。

以编程方式生成客户端类:

  1. 创建 %SOAP.WSDL.Reader 的实例。
  2. (可选)设置属性来控制实例的行为。有关详细信息,请参阅 %SOAP.WSDL.Reader 的类文档。

请注意,如果 WSDL 位于使用 SSL 的位置,%SOAP.WSDL.Reader 将(默认情况下)检查证书服务器名称是否与用于连接到服务器的 DNS 名称相匹配。如果这些名称不匹配,则不允许连接。此默认行为可防止中间人攻击,并在 RFC 28183.1 节中进行了描述;另请参阅 RFC 2595在新选项卡中打开,第 2.4 节。

要禁用此检查,请将实例的 SSLCheckServerIdentity 属性设置为 0

  1. 如果您需要以 %SOAP.WSDL.Reader 不直接支持的方式控制 HTTP 请求,请执行以下操作:

a. 创建 %Net.HttpRequest 的实例并根据需要设置其属性。

b. 对于 %SOAP.WSDL.Reader 实例,将 HttpRequest 属性设置为等于您刚刚创建的 %Net.HttpRequest 实例。

  1. 调用实例的 Process() 方法:
method Process(pLocationURL As %String, pPackage As %String = "") as %Status 

注意:如果此包与现有包相同,则默认情况下该工具会覆盖任何具有相同名称的现有类。要防止该工具覆盖类定义,请将以下内容添加到该类定义中:Parameter XMLKEEPCLASS = 1;

下面显示了一个终端会话示例:

set r=##class(%SOAP.WSDL.Reader).%New() 
GSOAP>set url="https://devsys:52773/csp/mysamples/GSOP.AddComplexWS.CLS?WSDL=1"
 
GSOAP>d r.Process(url) 
Compilation started on 11/09/2009 12:53:52 with qualifiers 'dk'
Compiling class AddComplex.ns2.ComplexNumber
Compiling routine AddComplex.ns2.ComplexNumber.1
Compilation finished successfully in 0.170s.
 
Compilation started on 11/09/2009 12:53:52 with qualifiers 'dk'
Compiling class AddComplex.AddComplexSoap
Compiling routine AddComplex.AddComplexSoap.1
Compiling class AddComplex.AddComplexSoap.Add
Compiling routine AddComplex.AddComplexSoap.Add.1
Compilation finished successfully in 0.363s.

WSDL URLWeb 应用程序的一部分,可能受到密码身份验证的保护。有关在这种情况下使用 WSDL 生成 Web 客户端或第三方 Web 客户端的详细信息,请参阅使用受密码保护的 WSDL URL

在所有情况下,也可以在提供所需的用户名和密码后从浏览器检索 WSDL,将其保存为文件并使用该文件。

上一篇 下一篇

猜你喜欢

热点阅读