没有 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 服务就像菜单之于餐馆。你可以在网上下载菜单,也可以去餐厅拿菜单,或者如果菜单从印刷厂运到餐厅时有人掉了,你可以在街上找。但是如果你想在餐厅消费食物,你必须去餐厅,你不消费菜单本身。
您可能会觉得有用的其他一些详细信息:
- The WSDL is not the SOAP web service
- Is it mandatory to have a WSDL definition accessible using ?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 服务就像菜单之于餐馆。你可以在网上下载菜单,也可以去餐厅拿菜单,或者如果菜单从印刷厂运到餐厅时有人掉了,你可以在街上找。但是如果你想在餐厅消费食物,你必须去餐厅,你不消费菜单本身。
您可能会觉得有用的其他一些详细信息:
- The WSDL is not the SOAP web service
- Is it mandatory to have a WSDL definition accessible using ?wsdl?