我不知道我在设置cookie时做错了什么?

时间:2013-07-03 16:23:31

标签: node.js cookies

所以我使用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移动到登录帖子中,但它无效...

请帮忙!

1 个答案:

答案 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/