【问题标题】:Passport.js express google oauth 502 Bad Gateway on nginxPassport.js 在 nginx 上表达 google oauth 502 Bad Gateway
【发布时间】:2016-11-23 02:36:08
【问题描述】:

我正在尝试按照本指南使用 passport.js 为我的 Express.js 应用程序实现一个简单的 Google OAuth(只需将 facebook 替换为 googlehttps://github.com/passport/express-4.x-facebook-example/blob/master/server.js

当我在本地尝试时,一切似乎都运行良好。当我将它部署到我的 Ubuntu 生产服务器时,我在从 Google 到 /login/google/return 端点的重定向回调期间收到 502 Bad Gateway 错误。

app.get('/login/google/return', 
  passport.authenticate('google', { failureRedirect: '/login' }),
  function(req, res) {
    res.redirect('/');
  });

如果我注释掉passport.authenticate('google', {..}) 行,那么错误就会消失。在检查 nginx 错误日志时,我看到了这个错误

upstream sent too big header while reading response header from upstream

这是 nginx 的服务器配置块:

location /auth/ {
   proxy_pass http://0.0.0.0:3000/;
}

这意味着我会通过转到https://example.com/auth/login/google 来登录google,然后被重定向到https://example.com/auth/login/google/return?code=4/adasfdafdsfd#,然后发生502 错误。

我曾尝试在我的 OS X 开发机器上设置类似的 nginx 环境,但那里没有出现问题。

我也尝试将以下内容添加到 nginx 块配置中,但这似乎也无济于事

proxy_buffers 8 16k;

对于如何调试/解决此问题,我束手无策。任何人的建议将不胜感激。这是到目前为止我的项目的链接https://github.com/tnguyen14/auth/blob/master/index.js

【问题讨论】:

  • 只是为了确保我理解正确,如果你去example.com/auth/login/google你会得到你的登录页面,但如果你去example.com/auth/login/google/return你会得到502。你真的试过去@987654325 @?只需在地址栏中输入该地址并回车,您会得到 502 吗?
  • @Molda 如果我直接转到/login/google/return,它会很好地工作,因为它会重定向到 Google 的帐户选择器页面。只有当 Google 使用 502 发生的代码重定向到 /login/google/return 时。我认为您链接的答案不太相关,因为我没有使用 fastcgi。

标签: node.js express nginx oauth passport.js


【解决方案1】:

所以我很接近。 proxy_buffers 8 16k; 还不够。将以下两行添加到 nginx 修复它:

proxy_buffers 8 16k;
proxy_buffer_size 32k;

更新:原来,它抱怨标题大小的原因是因为我没有充分serialize 用户配置文件,所以对象对于 cookie 来说太大了。因为我使用的是cookie-session,所以所有的数据都被塞进了cookie,变得太大了。

在不添加 nginx 配置的情况下,修剪将通过护照会话序列化的内容可以解决此问题。

【讨论】:

    猜你喜欢
    • 2020-05-15
    • 1970-01-01
    • 2023-03-20
    • 2019-12-17
    • 2014-07-08
    • 2018-04-23
    • 2021-02-24
    • 1970-01-01
    • 2022-08-16
    相关资源
    最近更新 更多