没有 WSDL 怎么可能进行 SOAP 调用?

How is a SOAP call possible without WSDL?

我对下面的 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 粗略接受的输入和 returns 作为输出的蓝图。那么在没有 WSDL 的情况下触发 SOAP 请求是否明智?

这是如何工作的?

WSDL 不是您的网络服务。

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

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

打个(可能很愚蠢的)类比,WSDL 之于 SOAP Web 服务就像菜单之于餐馆。你可以在网上下载菜单,也可以去餐厅拿菜单,或者如果菜单从印刷厂运到餐厅时有人掉了,你可以在街上找。但是如果你想在餐厅消费食物,你必须去餐厅,你不消费菜单本身。

您可能会觉得有用的其他一些详细信息: