没有 WSDL 的 SOAP 调用如何可能?

问题描述

我对我的 SOAP 调用在下面的工作方式感到困惑。

我们对我们的软件进行了产品升级,托管在 https://"+host+"/tc/services/BotOps-2018-11-ASMLBotOps?wsdl 的 WSLD 被移到了无法通过网络访问的其他位置。

我现有的代码如下所示:

var options = {​​​​​​​​
  url:"https://"+host+"/tc/services/BotOps-2018-11-ASMLBotOps?wsdl",method:'POST',body:xml,headers: {​​​​​​​​
    'Content-Type':'text/xml;charset=utf-8','Content-Length':xml.length,'SOAPAction':"asmlValidateUserAdminBotOpsService",'Cookie':from
  }​​​​​​​​
}​​​​​​​​;
       
var xml = `<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:asm="http://a5oa.com/Schemas/BotOps/2018-11/ASMLBotOps">
    <soapenv:Header/>
    <soapenv:Body>
       <asm:AsmlValidateUserAdminBotOpsServiceInput>
          <asm:asmlValidateUserIsAdminopsInput pszAsmlTcUserID="`+args[1]+`" pszRequestorUserId="`+args[2]+`"/>
       </asm:AsmlValidateUserAdminBotOpsServiceInput>
    </soapenv:Body>
 </soapenv:Envelope>`;

这在没有我们的产品升级的情况下运行良好,我理解。但是,如果 WSDL 被移动到一个无法访问的不同位置,并且我所指的 url 现在没有任何意义,那么这个 Web 服务请求怎么可能仍然按预期工作?我原以为 Web 服务现在会失败,因为 WSDL 不存在,但它仍然有效。

我在某处读到 WSDL 就像其他语言中的头文件,其中包含 SOAP 粗略地接受作为输入并作为输出返回的蓝图。那么在没有 WSDL 的情况下触发 SOAP 请求是否明智?

这是如何工作的?

解决方法

WSDL 不是您的网络服务。

WSDL 用于描述网络服务合同,以便您了解如何调用网络服务(它具有哪些操作、哪些参数名称、参数类型、在哪里可以找到其端点等)。然后调用 Web 服务,而不是 WSDL。

另一件要提及的事情是您获得了一个 WSDL(通常按照在 Web 服务端点上使用 ?wsdl 参数的约定),但是您通过执行 POST 来调用 Web 服务。 因此,如果服务仍然存在并接受 POST 请求,那么您可以从何处检索其 WSDL 并不重要。

提供一个(可能是愚蠢的)类比,WSDL 适用于 SOAP Web 服务,就像菜单适用于餐厅一样。您可以在线下载菜单,您可以在餐厅获得菜单,或者如果有人在从印刷厂运送到餐厅时将其丢弃,您可以在街上找到菜单。但是如果你想在餐厅消费食物,你必须去餐厅,你不消费菜单本身。

您可能会觉得有用的其他一些细节: