使用 Node 通过 https 调用 SOAP Web 服务
Using Node to call SOAP Web Service over https
我正在尝试使用 node-soap https://github.com/vpulim/node-soap 调用 Web 服务,但我在使用带有 https 的模块时遇到问题。
在下面的代码中,我使用了 http,我可以看到函数并记录 About
函数的 describe()
。 (响应为空,可能是因为使用 http(?) 时 WS 是这样设置的)
var soap = require('soap');
var url = "http://XXXXX/service.svc?DocArchiveService/DocArchiveV201409";
var auth = "Basic " + new Buffer("USERXXX" + ":" + "PWYYY").toString("base64");
var args = {};
soap.createClient(url, { wsdl_headers: {Authorization: auth} }, function(err, client) {
console.log(client.describe().DocArchiveV201409.DocArchiveV201409Soap.About);
client.DocArchiveV201409.DocArchiveV201409Soap.About(args, function(err, result){
if (err) throw err;
console.log(result);
});
});
输出:
{ input: {}, output: { AboutResult: 's:string' } }
错误消息(这很好,因为无论如何响应都是空的):
Error: Cannot parse response
at finish (E:\Qlikview\SourceDocuments\UnderDevelopment\Node\node_modules\so
ap\lib\client.js:383:19)
我的问题是在使用 https 时我得到了一个未定义的客户端。
E:\Qlikview\SourceDocuments\UnderDevelopment\Node\Soap.js:23
console.log(client);
^ ReferenceError: client is not defined
at Object.anonymous (E:\Qlikview\SourceDocuments\UnderDevelopment\Node\Soa p.js:23:13)
有人用过 node-soap 和 https 吗?
编辑:
由于下面的结果表明我需要先获得证书。我曾尝试在没有证书的情况下使用 SoapUI,但效果很好。也许有一些参数 createClient
我可以在 node-soap 中使用?
console.log(错误)returns:
{ Error: unable to get local issuer certificate
at Error (native)
at TLSSocket.<anonymous> (_tls_wrap.js:1079:38)
at emitNone (events.js:86:13)
at TLSSocket.emit (events.js:185:7)
at TLSSocket._finishInit (_tls_wrap.js:603:8)
at TLSWrap.ssl.onhandshakedone (_tls_wrap.js:433:38) code: 'UNABLE_TO_GET_IS
SUER_CERT_LOCALLY' }
已从 tls
特定错误中清除,您无法创建 soap 客户端
通过调用 soap.createClient
。它正在返回 err
和 undefined
客户端,这就是后续调用失败的原因。
certificate
问题背后的主要原因可能是 soap 服务器证书由 internal CA
签名或 soap 服务器正在使用 self-signed certificate
。
可用于解决该问题的可能解决方案是
[不推荐] 通过在请求时禁用 SSL
检查来忽略特定于证书的警告。
例如
var request = require('request');
var specialRequest = request.defaults({
strictSSL: false
});
[推荐]提供root/intermediate个CA的证书来验证远程证书。
var request = require('request');
var specialRequest = request.defaults({
agentOptions: {
ca: fs.readFileSync('ca.cert.pem') //path of CA cert file
}
);
对于这两种解决方案,将此 specialRequest
传递给 createClient
。
soap.createClient(url, {
wsdl_headers: {Authorization: auth},
request : specialRequest
}, function(err, client) {
//your code
});
我刚刚浏览了文档并提出了解决方案。它可能有效也可能无效,但从逻辑上值得尝试。我无法测试上述解决方案,但它应该有效。
希望对你有帮助。
对于推荐的解决方案 - 提供 root/intermediate CA 证书来验证远程证书,试试这个 -
var request = require('request');
var specialRequest = request.defaults({ ca: fs.readFileSync('ca.cert.pem') //path of CA cert file );
var auth = "Basic " + new Buffer.from("myUsername:myPassword").toString("base64");
var options = { wsdl_headers: { Authorization: auth }, request: specialRequest };
soap.createClient(url, options, function (err, client) {
client.myFunction(args, function (err, result) {
console.log(result);
});
});
我正在尝试使用 node-soap https://github.com/vpulim/node-soap 调用 Web 服务,但我在使用带有 https 的模块时遇到问题。
在下面的代码中,我使用了 http,我可以看到函数并记录 About
函数的 describe()
。 (响应为空,可能是因为使用 http(?) 时 WS 是这样设置的)
var soap = require('soap');
var url = "http://XXXXX/service.svc?DocArchiveService/DocArchiveV201409";
var auth = "Basic " + new Buffer("USERXXX" + ":" + "PWYYY").toString("base64");
var args = {};
soap.createClient(url, { wsdl_headers: {Authorization: auth} }, function(err, client) {
console.log(client.describe().DocArchiveV201409.DocArchiveV201409Soap.About);
client.DocArchiveV201409.DocArchiveV201409Soap.About(args, function(err, result){
if (err) throw err;
console.log(result);
});
});
输出:
{ input: {}, output: { AboutResult: 's:string' } }
错误消息(这很好,因为无论如何响应都是空的):
Error: Cannot parse response at finish (E:\Qlikview\SourceDocuments\UnderDevelopment\Node\node_modules\so ap\lib\client.js:383:19)
我的问题是在使用 https 时我得到了一个未定义的客户端。
E:\Qlikview\SourceDocuments\UnderDevelopment\Node\Soap.js:23 console.log(client); ^ ReferenceError: client is not defined at Object.anonymous (E:\Qlikview\SourceDocuments\UnderDevelopment\Node\Soa p.js:23:13)
有人用过 node-soap 和 https 吗?
编辑:
由于下面的结果表明我需要先获得证书。我曾尝试在没有证书的情况下使用 SoapUI,但效果很好。也许有一些参数 createClient
我可以在 node-soap 中使用?
console.log(错误)returns:
{ Error: unable to get local issuer certificate
at Error (native)
at TLSSocket.<anonymous> (_tls_wrap.js:1079:38)
at emitNone (events.js:86:13)
at TLSSocket.emit (events.js:185:7)
at TLSSocket._finishInit (_tls_wrap.js:603:8)
at TLSWrap.ssl.onhandshakedone (_tls_wrap.js:433:38) code: 'UNABLE_TO_GET_IS
SUER_CERT_LOCALLY' }
已从 tls
特定错误中清除,您无法创建 soap 客户端
通过调用 soap.createClient
。它正在返回 err
和 undefined
客户端,这就是后续调用失败的原因。
certificate
问题背后的主要原因可能是 soap 服务器证书由 internal CA
签名或 soap 服务器正在使用 self-signed certificate
。
可用于解决该问题的可能解决方案是
[不推荐] 通过在请求时禁用
SSL
检查来忽略特定于证书的警告。 例如var request = require('request'); var specialRequest = request.defaults({ strictSSL: false });
[推荐]提供root/intermediate个CA的证书来验证远程证书。
var request = require('request'); var specialRequest = request.defaults({ agentOptions: { ca: fs.readFileSync('ca.cert.pem') //path of CA cert file } );
对于这两种解决方案,将此 specialRequest
传递给 createClient
。
soap.createClient(url, {
wsdl_headers: {Authorization: auth},
request : specialRequest
}, function(err, client) {
//your code
});
我刚刚浏览了文档并提出了解决方案。它可能有效也可能无效,但从逻辑上值得尝试。我无法测试上述解决方案,但它应该有效。
希望对你有帮助。
对于推荐的解决方案 - 提供 root/intermediate CA 证书来验证远程证书,试试这个 -
var request = require('request');
var specialRequest = request.defaults({ ca: fs.readFileSync('ca.cert.pem') //path of CA cert file );
var auth = "Basic " + new Buffer.from("myUsername:myPassword").toString("base64");
var options = { wsdl_headers: { Authorization: auth }, request: specialRequest };
soap.createClient(url, options, function (err, client) {
client.myFunction(args, function (err, result) {
console.log(result);
});
});