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

随笔3周前发布 五雾
24 0 0

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

类包名称的 SOAP 向导规则

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

  • Web 客户端包和 Web 服务包字段中指定的包包含主要生成的 Web 客户端或 Web 服务类。这些值由在向导的上一页中输入的内容进行初始化。
  • 如果向导还生成一个策略类(因为 WSDL 包含 WS-Policy 信息),则默认情况下该类位于同一包中。要指定不同的包,请指定配置子包的值。

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

  • 对于生成的任何支持类,向导会检测 WSDL 中使用的所有名称空间。默认情况下,它将生成的类组织到包中,每个名称空间对应一个包。

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

并非所有名称空间都必须对应于生成的类。例如,本示例中使用的 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 

  • pLocationURL – 必须是 Web 服务的 WSDLURLWSDL 文件的名称(包括其完整路径)。根据 Web 服务的配置,可能需要附加提供合适用户名和密码的字符串;请参阅示例。
  • pPackage – 是生成的类的包的名称。如果未指定包, 将使用服务名称作为包名称。

注意:如果此包与现有包相同,则默认情况下该工具会覆盖任何具有相同名称的现有类。要防止该工具覆盖类定义,请将以下内容添加到该类定义中: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,将其保存为文件并使用该文件。

© 版权声明

相关文章

暂无评论

您必须登录才能参与评论!
立即登录
暂无评论...