我长时间一直盯着同样的问题/答案。
我正在尝试在req.session变量中设置我的用户ID
这是我的app.js堆栈
/**
* Module dependencies.
*/
var express = require('express')
, routes = require('./routes')
, cors = require('cors')
, mongoose = require('mongoose')
, User = require('./user-model')
, path = require('path')
, mysql = require('mysql');
app = express()
/**
* Middleware.
*/
app.use(cors());
app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({ secret: 'supercalafragalistic' }));
app.locals.pretty = true;
app.use(express.static(path.join(__dirname, 'public')));
app.set('view engine', 'jade');
...
app.get('/someRoute', routes.someRoute)
我已经将app.router从上到下移动了。目前它是隐含的(我刚删除它,因为我剥离了我的代码寻找错误)。我已导出应用程序,包含在路线中的应用程序(也已擦除)。我添加了中间件。我迷路了......
这是我的路线堆栈
//routes/index.js
//requires
var User = require('../user-model')
,qs = require('querystring')
,http = require('http')
,mysql = require('mysql')
,connection = mysql.createConnection({
edited
});
/**
* Set up application.
*/
connection.connect(function(err){
if(err) console.log('failed to connect to mysql because'+ err);
else console.log('connected to mysql');
})
我将id保存在登录路由中:
//login processing route
exports.logIn = function(req, res, next){
console.log('log in request from '+req.body.name);
User.findOne({name:req.body.name}, function(err, user, next){
if(err) return next(err);
if(!user) return res.end();
//check password
user.comparePassword(req.body.password, function(err, isMatch){
if(err) res.send('failed to find user');
console.log(""+isMatch);
if(isMatch){
console.log(user._id.toString()+' user loggd in');
//set session cookie
req.session.loggedIn = user._id.toString();
console.log('req.session.loggedIn set to :'+req.session.loggedIn );
res.send(user);
}else {
res.send('User not found try again');
}
});
});
但是,在所有其他路由中,变量未定义:
// clock status
exports.clockStatus = function(req, res, next){
var user = req.session.loggedIn;
console.log('Status route, userID: '+user);
if(user){
我在"Cannot access req.session variables in Express/NodeJS"找到了答案,但最后一部分落后了:
在您的情况下,您已分配req.session.user = user;只有在 /登录请求。它不能用于进一步的请求(/ auth)。
您必须通过会话ID在/ auth请求中获取用户信息。 (或者)你可以使用护照进行身份验证。
怎么样?你如何“通过会话ID获取/ auth请求中的用户信息”?
请提出任何你需要的东西来理顺我。 我很难过。我已经尝试了一些愚蠢的东西!
答案 0 :(得分:0)
如果您未在浏览器中首先登录,则该变量在其他路径中未定义。这是我的测试代码:
var express = require('express');
var cors = require('cors');
app = express();
app.use(cors());
app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({ secret: 'this is a test' }));
app.use(express.static(require('path').join(__dirname, 'public')));
app.get('/login', function(req, res) {
req.session.uid = 'user001';
res.send(req.session);
});
app.get('*', function(req, res) {
res.send(req.session);
});
app.listen(8080);
首先在浏览器中访问http://localhost/login
。然后在此浏览器中访问其他URL(例如,http://localhost/test
),返回会话中的用户ID。因此,代码的其他部分可能存在问题。
测试设置: