使用Node通过https

时间:2016-12-23 10:23:13

标签: node.js soap node-soap

我正在尝试使用node-soap https://github.com/vpulim/node-soap来调用Web服务,但我在使用 https 模块时遇到问题。

在下面的代码中,我使用 http ,我可以看到这些函数并记录describe()函数的About。 (响应是空的,可能是因为使用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' } }

错误信息(这很好,因为无论如何响应都是空的):

  

错误:无法解析响应       完成后(E:\ Qlikview \ SourceDocuments \ UnderDevelopment \ Node \ node_modules \ so   AP \ lib中\ client.js:383:19)

我的问题是,当使用https时,我会得到一个未定义的客户端。

  

E:\的QlikView \ SourceDocuments \不发达\节点\ Soap.js:23   的console.log(客户端);               ^ ReferenceError:未定义客户端       at Object.anonymous(E:\ Qlikview \ SourceDocuments \ UnderDevelopment \ Node \ Soa p.js:23:13)

是否有人使用过https的node-soap?

修改 以下结果表明我需要先获得证书。我已经尝试使用没有证书的SoapUI,并且工作正常。也许我可以在node-soap中使用createClient的一些参数?

console.log(err)返回:

{ 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' }

2 个答案:

答案 0 :(得分:2)

tls特定错误清除后,您无法创建soap客户端 通过调用soap.createClient。它正在返回errundefined客户端,这就是后续调用失败的原因。

certificate问题背后的主要原因可能是肥皂服务器证书由internal CA签署,或肥皂服务器使用self-signed certificate

可用于解决该问题的可能解决方案是

  1. [不推荐]通过在请求时禁用SSL检查来忽略特定于证书的警告。 e.g。

    var request = require('request');
    var specialRequest = request.defaults({
       strictSSL: false
    );
    
  2. [推荐]提供CA的根/中间证书以验证远程证书。

    var request = require('request');
    var specialRequest = request.defaults({
       agentOptions: {
          ca: fs.readFileSync('ca.cert.pem') //path of CA cert file
       }
    );
    
  3. 对于这两种解决方案,请将此specialRequest传递给createClient

        soap.createClient(url, { 
            wsdl_headers: {Authorization: auth},
            request : specialRequest
        }, function(err, client) {
            //your code
        });
    

    我刚刚完成了文档并提出了解决方案。它可能有效,也可能无效,但值得尝试逻辑。我无法测试上面提到的解决方案,但它应该工作。

    希望它对你有所帮助。

答案 1 :(得分:1)

对于推荐的解决方案-提供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);
    });
});