Express、http-proxy-middleware 和 net::ERR_CONNECTION_REFUSED

Express, http-proxy-middleware and net::ERR_CONNECTION_REFUSED

我一直在尝试调试我遇到的一个问题,它有一个使用 http-proxy-middleware 将请求转发到另一个后端服务的 Express 应用程序。有第三方应用程序通过发出请求来调用我的服务器,该请求在它发送的 URL 中明确使用 IP 地址。当 运行 在我的开发机器上本地时,它使用机器的本地 IP 地址(不是本地主机或环回 127.0.0.1)。

我已经将我的服务器剥离到绝对最小值,并且我正在代理一个只响应空 JSON 对象的服务。所以所有其他因素都被删除了。它只是一个简单的快速应用程序和代理。

服务器

var express = require('express');
var proxyMiddleware = require('http-proxy-middleware');
var port = 4000;

var app = express();
var options = {
  target: 'http://jsonplaceholder.typicode.com',
  logLevel: 'debug'
}

var apiProxy = proxyMiddleware('/myportfolio', options);
app.use(apiProxy);

app.listen(port, 'localhost', (err) => {
  if (err) {
    console.log(err);
    process.exit(1);
  }

  // So we can see a message whilst it bundles
  console.log(`now running on port: ${port}\n`);
});

我的应用程序启动并显示消息

'now running on port: 4000'

我启动浏览器并发送以下内容:

http://localhost:4000/myportfolio

并得到

// 20161023082019
// http://localhost:4000/myportfolio
{
}

这是绝对好的,也是预期的答案,到目前为止一切顺利。 然后我可以切换到使用环回 IP 地址

当我打字时

http://127.0.0.1:4000/myportfolio

我明白了

// 20161023082943
// http://127.0.0.1:4000/myportfolio
{
}

然而当我使用

http://192.168.1.126:4000/myportfolio

我没有得到任何返回,Chrome 网络选项卡显示以下错误

GET http://192.168.1.126:4000/myportfolio net::ERR_CONNECTION_REFUSED

和chrome显示标准无法连接消息。

This site can’t be reached
192.168.1.126 refused to connect.

我已经检查了本地机器的 IP 地址及其正确性

和'Network Utility'告诉我的一样

并检查终端中的地址给出:

$ ifconfig | grep inet
inet 127.0.0.1 netmask 0xff000000 
inet6 ::1 prefixlen 128 
inet6 fe80::1%lo0 prefixlen 64 scopeid 0x1 
inet6 fe80::4c:3ebe:e51d:819f%en0 prefixlen 64 secured scopeid 0x4 
inet 192.168.1.126 netmask 0xffffff00 broadcast 192.168.1.255
inet6 fe80::18a8:e9ff:fe89:25e7%awdl0 prefixlen 64 scopeid 0x8 
inet6 fe80::694c:e86:8b39:47f7%utun0 prefixlen 64 scopeid 0xa 
inet6 fe80::45eb:e4b2:c242:48b%utun2 prefixlen 64 scopeid 0xc 
inet6 fe80::859:d69c:1aec:7a59%utun1 prefixlen 64 scopeid 0xb 
inet6 fe80::8d7:fd2c:e131:6832%utun3 prefixlen 64 scopeid 0xd 
$ 

$ netstat -an | grep 4000
tcp4       0      0  127.0.0.1.4000         *.*                    LISTEN     
$

第三方软件也会导致同样的 net::ERR_CONNECTION_REFUSED 发生(如您所料),但由于我已经完成了将其与我的开发集成的工作,所以我需要找到解决此问题的方法直接通过 IP 调用而不是本地主机或 127.0.0.1.

好的,经过大约几个小时的内部搜索并最终查看中间件的问题列表

答案很简单 - 我只需要通过传入不同的主机(不是通常的 'localhost')来打开 Express APP

app.listen(port, '0.0.0.0', (err) => {
  if (err) {
    console.log(err);
    process.exit(1);
  }

  // So we can see a message whilst it bundles
  console.log(`now running on port: ${port}\n`);
});

我会在这里留下这个答案,以防将来对其他人有用。

我本可以输入我的特定 IP 地址,但由于我使用的是 DHCP,因此“0.0.0.0”现在就足够了...

:)