我的问题和这个问题类似,但没有洞察到他的解决方案。
我在用Passport认证Instagram。验证成功后,用户被定向到“/”。此时,请求具有user对象(也称为IT's working)。但是,一旦我重定向,req.user是未定义的。:'(
奇怪的是,每个请求都会调用Passport.DeserializeUser。它成功地获取了user对象,但在中间件的某个地方,req.user没有被设置(或被取消设置)。
// on successful auth, goto "/"
app.get('/', function(req, res) {
// if the request has the user object, go to the user page
if (req.user) {
res.redirect("/user/" + req.user._id);
}
res.render("index");
}
app.get('/user/:uid', function(req, res) {
console.log(req.user) // undefined
}
你为你的应用程序设置了会话状态吗?你需要这样的东西。。。
app.use(session({ secret: 'anything' }));
app.use(passport.initialize());
app.use(passport.session());
我的问题是在客户端使用fetch时没有指定发送cookie。在请求中包含credentials:'include'字段后,它就可以工作了。
fetch('/api/foo', {credentials: 'include'})
我对Node非常陌生,但对我来说这是一个中间件问题。添加了bodyParser并重新排列以修复。
损坏的代码:
app.use(express.cookieParser('secret'));
app.use(express.cookieSession());
app.use(express.session({ secret: 'anything' }));
app.use(passport.initialize());
app.use(passport.session());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
工作代码:
app.use(express.static(path.join(__dirname, 'public')));
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(express.session({ secret: 'anything' }));
app.use(passport.initialize());
app.use(passport.session());
app.use(app.router);
希望这有帮助