NodeJS express-session(为什么未定义?)

时间:2015-12-13 01:14:57

标签: javascript node.js session express

这是我的“登录”图层:

app.post('/sign', function(req, res) {
sess=req.session;

var query = 'SELECT * FROM ?? where ??=? AND ??=?';
var table = ["users", "name", req.body.login, "password", md5(req.body.password)];
query = mysql.format(query, table);
connection.query(query, function(err, rows) {
  if(err) {
    console.log(err);
    return;
  } else if(rows.length > 0) {
    console.log("You have been sucessfully logged in.");
    sess.login = req.body.login;
    console.log(sess.login);
  } else {
    console.log("The name or password is incorrect.");
  }
});
res.end();
});

如您所见,应该在用户存在于数据库中时创建会话(实际上,console.log(sess.login)在会话的控制台正确内容中显示,因此会话已创建)。问题是当我更改图层时。

app.get('/', function(req, res) {
  sess = req.session;
  if(sess.login) {
    res.render('indexo');
  } else {
    res.render('index');
  }
  console.log(sess.login);
});

为什么sess.login在这里未定义? 这是我的其余代码(在图层之上)

/*******************************************/
/**/  var express         = require('express'),
/**/      session         = require('express-session'),
/**/      bodyParser      = require('body-parser'),
/**/      ejs             = require('ejs'),
/**/      mysql           = require('mysql'),
/**/      md5             = require('md5');
/*******************************************/

var app = express();
var connection = mysql.createConnection({
  host: 'localhost',
  user: 'root',
  password: '',
  database: 'simpledatabase'
});

connection.connect(function(error) {
  if(error) {
    console.log("There is a problem with connection to the database.");
    return;
  }
    console.log("Connected with a database.");
});

app.use(session({
    secret: 'test session',
    resave: false,
    saveUninitialized: true
}));
app.use(express.static('public'));
app.use('/js', express.static('bower_components/jquery/dist'));
app.use(bodyParser.json());
app.set('view engine', 'ejs');
app.set('views', 'public/views');

var sess;

当我以这种方式创建sess.login时,sess.login是可见的:

app.post('/sign', function(req, res) {
sess=req.session; 
sess.login = req.body.login; /****** HERE ******/
var query = 'SELECT * FROM ?? where ??=? AND ??=?';
var table = ["users", "name", req.body.login, "password", md5(req.body.password)];
query = mysql.format(query, table);
connection.query(query, function(err, rows) {
  if(err) {
    console.log(err);
    return;
  } else if(rows.length > 0) {
    console.log("You have been sucessfully logged in.");
  } else {
    console.log("The name or password is incorrect.");
  }
});
res.end();
});

但是你知道我只想在用户存在于数据库中的情况下创建会话。

问题简而言之: 如果我在'if'中创建会话,则sess.login仅在'/ login'层中可见。所有与数据库的连接都已正确设置,一切正常。

感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

因此,您的问题是,您在回调的外部为查询调用了res.end()。这基本上终止了响应过程,并且您没有机会更新req.session,因为回调在响应过程结束后稍后(或更长时间)被调用。尝试将res.end放入回调中,我认为事情会在那之后发挥作用。