我正在尝试调用其他应用程序的安全REST服务。还提供客户端证书,但收到如下错误:
request function
Response: IncomingMessage {
_readableState:
ReadableState {
objectMode: false,
highWaterMark: 16384,
buffer: BufferList { head: null, tail: null, length: 0 },
length: 0,
.........
authorized: false,
**authorizationError: 'SELF_SIGNED_CERT_IN_CHAIN',**
encrypted: true,
..........
我尝试使用postman和rest客户端测试它并获得响应。 但是没有通过上面的Node JS程序/代码。 因此,根据我的理解,由于SSL拦截代理,这种情况正在发生; npm检测到此并抱怨。
我已经在Node JS应用程序中使用POST方法实现了Rest客户端以使用REST服务,如下所示。
var https = require('https');
var fs = require('fs');'
process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";
var options = {
host: '<HOSTNAME>',
port: '<PORT>',
path: '<PATH>',
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Accept': 'application/json',
'Authorization': '',
},
ca: [ fs.readFileSync('<.jks file/ certificate name>') ],
checkServerIdentity: function (host, cert) {
},
rejectUnauthorized:false,
body: ''
};
var req = https.request(options, function(res) {
console.log('request function')
console.log("Response: ", res);
res.on('data', function(d) {
'' +
'?' });
});
req.end();
req.on('error', function(e) {
console.error(e);
});
我尝试了其他解决方案 “npm config set strict-ssl false”命令但无法正常工作。
我也试过了 rejectUnauthorized:false和process.env.NODE_TLS_REJECT_UNAUTHORIZED =“0” 你可以在我的代码中看到,但到目前为止没有任何工作。
Few required entries in .npmrc file are as below:
registry=https://registry.npmjs.org/
strict-ssl=false
cafile= <certificate path>
我尝试了所有可能性,但如上所述收到错误,请提示我是否遗漏了任何内容或需要更新任何内容。谢谢。
答案 0 :(得分:0)
我找到的一个解决方案是我可以忽略主机名检查以使用Node JS来使用Rest服务,但是无法找到如何使用上面的Node JS代码忽略主机名。