我正试图找出为什么我的代码因此错误而失败:
{ Error: connect ECONNREFUSED 127.0.0.1:443
at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1082:14)
errno: 'ECONNREFUSED',
code: 'ECONNREFUSED',
syscall: 'connect',
address: '127.0.0.1',
port: 443 }
,该错误的堆栈跟踪如下所示:
Error: connect ECONNREFUSED 127.0.0.1:443
at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1082:14)
我正在建立网络连接,但是我没有尝试连接到本地主机。
我正在使用的网络代码在其他情况下也可以正常工作(并连接到正确的主机)。
我使用的是brew install提供的节点11.6.0,看来在brew“ Cellar”目录结构中唯一出现的字符串“ net.js”是在节点二进制文件本身中。换句话说,即使在
之后 brew install --build-from-source node
运行
find /usr/local/Cellar/node/11.6.0 -type f | xargs fgrep -l net.js
仅找到一个文件:/usr/local/Cellar/node/11.6.0/bin/node并且该目录树中没有net。*文件。
如果有关系,我的似乎触发此错误的代码如下:
const get_json_with_auth= async (channel, url) => {
const parsed_url= URL.parse(url);
return new Promise((good, fail) => {
let request= require('https').get({
hostname: parsed_url.hostname,
path: parsed_url.path,
headers: {
Authorization: get_auth('GET', channel, url)
}
});
console.log('url', url);
request.on('response', response=> {
const chunks= [];
response.on('data', data=> chunks.push(data));
response.on('end', ()=> good(JSON.parse(Buffer.concat(chunks).toString())));
});
request.on('error', err=> fail(err));
});
};
(我在OSX高山脉上。)
但是,再次,我使用的url中的主机名不能解析为localhost(在其他情况下也可以正常工作)。
如何隔离这样的问题?
答案 0 :(得分:0)
使用环境变量NODE_DEBUG ='net,tls,http,https'运行我的代码可以给我足够的信息来识别(并隔离)问题。