这是我的“登录”图层:
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'层中可见。所有与数据库的连接都已正确设置,一切正常。
感谢您的帮助。
答案 0 :(得分:0)
因此,您的问题是,您在回调的外部为查询调用了res.end()
。这基本上终止了响应过程,并且您没有机会更新req.session,因为回调在响应过程结束后稍后(或更长时间)被调用。尝试将res.end放入回调中,我认为事情会在那之后发挥作用。