3

我正在使用 http-proxy-middleware ( https://github.com/chimurai/http-proxy-middleware#http-proxy-events ) 来实现一个简单的代理 (调用它my-proxy/) 到另一个 REST API (调用它/rest-api)这要求用户在 HTTP 标头中传递身份验证令牌auth-token。可以使用POST /rest-api/auth正文中的凭据从端点获取令牌。

我希望我的代理接受传入的请求并检查是否auth-token在请求标头中设置,如果没有执行 aPOST /rest-api/auth以检索令牌并auth-token在将请求传递给rest-api/.

在我指定的代理配置中

onProxyReq: function (proxyReq, req, res) {
        if (!req.header("auth-token")) {
            const authRequest = request({
                    url: 'rest-api/auth',
                    method: 'POST',
                    json: {"username": "user", "password": "pass"}
                },
                function (error, resp, body) {
                    proxyReq.setHeader("auth-token", body.token)
                }
            );
        }
    }

我可以看到body.token返回正确的令牌。但是,setHeader调用失败并显示Error [ERR_HTTP_HEADERS_SENT]: Cannot set headers after they are sent to the client.

我认为这意味着我修改的请求在等待回调之前已经发送到rest-api/,但我不知道在我的场景中如何最好地解决这个问题。

有什么帮助吗?

4

1 回答 1

3

我今天遇到了同样的问题。我通过使用单独的中间件(在 http 代理之前)来解决这个问题。

伪代码

// fix token stuff here in a separate middleware
app.use('/api', async (req, res, next) => {

    if (!req.session.token) {
       const resToken = await axios.post(token_url, data, options)
       req.session.token = resToken.data
    }
    next()
}

// proxy middleware options
const proxyOptions = {
  target: config.gateway.url, // target host
  changeOrigin: true,
  pathRewrite: function(path, req) {
    return path.replace('/api', '')
  },
  onProxyReq: function onProxyReq(proxyReq, req, res) {
    // add custom header to request
    let token = req.session.token
    if (token) {
      proxyReq.setHeader('Authorization', `bearer ${token.access_token}`)
    }
  },
  logLevel: 'debug',
}

app.use(proxy('/api', proxyOptions))

希望这可以帮助!

于 2019-12-31T04:09:04.470 回答