所以我使用nodejs和mongodb并尝试在其中一个页面上设置cookie。
在app.js文件中,使用此
是非常标准的var express = require('express')
, app = express()
, dbUserModel = require('./models/user')
, db = require('./db')
, pass = require('./config/passport')
, passport = require('passport')
, routes = require('./routes/index')
, user = require('./routes/user')
, path = require('path')
, http = require('http')
, connect = require('connect')
, mongoose = require('mongoose')
, mongoConnect = mongoose.connect('mongodb://localhost/test5');
// all environments
app.configure(function(){
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.cookieParser('secret'));
///app.use(express.cookieSession());
app.use(express.methodOverride());
app.use(passport.initialize());
app.use(passport.session());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
});
app.get('/', routes.index)
app.get('/register', user.register);
app.post('/register', user.registerPost);
app.get('/registerError', user.registerError);
app.get('/registerThanks', user.registerThanks);
app.get('/login', user.login);
app.post('/login', user.loginPost);
app.get('/loginError', user.loginError);
app.get('/userProfile', user.userProfile);
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
console.log('Users: ' + db.collections.users);
});
然后我正在调用我的路线文件。
这是我的代码:
exports.login = function(req, res) {
res.render('login', {user: req.user, title: 'Weblio'});
};
exports.loginPost = function(req, res, next) {
passport.authenticate('local', function(err, user, info) {
if (err) { return next(err) }
if (!user) { return res.redirect('loginError'); }
req.logIn(user, function(err) {
if (err) { return next(err); }
return res.redirect('userProfile');
});
})(req, res, next);
};
exports.loginError = function (req, res) {
res.render('loginError', {title: 'Weblio'});
};
exports.userProfile = function(req, res) {
res.render('userProfile', {user: req.user, title: 'Weblio'});
res.cookie('name', 'test', { maxAge: 900000, httpOnly: true });
};
当我转到userProfile页面并在控制台中输入document.cookie时,它会显示一个空字符串作为结果。
我也尝试将res.cookie移动到登录帖子中,但它无效...
请帮忙!
答案 0 :(得分:1)
无论您使用何种编程语言,都无法在将响应标头发送到客户端后修改Cookie。致电res.render()
时,它会发送标题以及实际视图。
HTTP Cookie是发送给客户端的标头的一部分。
尝试在向客户端发送回复的res.cookie()
之前调用res.render()
。
此外,在致电app.use(express.cookieParser('secret'));
时,您正在通过提供'secret'参数来创建'已签名'的Cookie。
因此,在更改cookie时,您必须告诉快递您正在处理签名的cookie,如下所示:
res.cookie('name', 'test', {maxAge: 900000, httpOnly: true, signed: true});
您可以在此处详细了解Cookie:http://www.nczonline.net/blog/2009/05/05/http-cookies-explained/