0

我正在编写一个应用程序,它接受一个发布请求并设置一个从 POST 信息中提取的 cookie。我陷入了第 22 个问题。在第一个代码示例中,我可以设置 cookie 但无法访问数据,在第二个代码示例中,我可以访问数据但无法设置 cookie。我确定我错过了中间件如何工作的一些基本概念,但我无法终生找到我需要的信息。

下面的代码按预期创建了 cookie,但我的 post 变量变得未定义

var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , handshake = require('./routes/handshake')
  , http = require('http')
  , path = require('path');

var app = express();   
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(express.methodOverride()); 
app.use(function (req, res, next) {
    var cookie = req.cookies.cokkieName;
    console.log("cookie_name" , cookie);
    if (cookie === undefined)
    {
            //cookie is set but I can't use req.post.xxxx. It"s always undefined
        res.cookie("price", 111, { maxAge: 10000 });
        console.log('cookie has been created successfully');
    } 
    else
    {
        console.log('cookie exists', cookie);
    } 
    next();
});

app.use(app.router);
app.use(require('stylus').middleware(__dirname + '/public'));
app.use(express.static(path.join(__dirname, 'public')));
app.post('/handshake', handshake.token);

http.createServer(app).listen(app.get('port'), function(){
  console.log('Express server listening on port ' + app.get('port'));
});

以下代码执行 setCookie 回调(因为显示了控制台输出),并且在控制台上正确定义了变量,但未设置 cookie。

var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , handshake = require('./routes/handshake')
  , http = require('http')
  , path = require('path');

var app = express();

app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(express.methodOverride());


var setCookie = function (req, res, next) {
    var cookie = req.cookies.cokkieName;
    console.log("cookie_name" , cookie);
    if (cookie === undefined)
    {

        res.cookie("price", 111, { maxAge: 10000 }); 
            //in the console the post.body.xxxx data appears correctly but no cookie!!!
        console.log('cookie has been created successfully',post.body.xxx);
    } 
    else
    {
        console.log('cookie exists', cookie);
    } 
    next();
};
app.use(app.router);
app.use(require('stylus').middleware(__dirname + '/public'));
app.use(express.static(path.join(__dirname, 'public')));
app.post('/handshake', setCookie ,handshake.token);
http.createServer(app).listen(app.get('port'), function(){
  console.log('Express server listening on port ' + app.get('port'));
});

试图使代码更具可读性引入了太多与我的代码无关的错别字。我接受了这个建议并按以下方式更改了代码,但它仍然没有向客户端写入 cookie。

var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , handshake = require('./routes/handshake')
  , http = require('http')
  , crypt = require('crypto')
  , io = require('socket.io')
  , db = require('levelup')('./mydb')
  , path = require('path');

var app = express();
app.use(express.cookieParser());
app.use(express.bodyParser());

var cookieMiddleware = function (req, res, next) {
    var cookie = req.cookies.user;
    console.log("cookie_name" , cookie);
    if (cookie === undefined)
    {
        // no: set a new cookie
        var random = Math.random().toString();
        random=random.substring(2,random.length);       
        sessionToken = Date.now()  + random;
        salt = sessionToken + req.body.address;
        sha2 = crypt.createHash('sha256');
        sha2.update(sessionToken);
        var price = req.body.price;
        var encryptedSession = sha2.digest('hex');

    console.log('post body',price );
        res.cookie('user','price' , { maxAge: 100000 });
        console.log('existing cookies', req.cookies);
    } 
    else
    {
        console.log('cookie exists', req.cookies);
    } 
    next(); 
};
//development only
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}

app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.logger('dev'));
app.use(express.session({secret: "TheSuperSecretStringForHashing"}));
app.use(express.methodOverride());
app.use(app.router);
//app.use(express.favicon());
app.use(require('stylus').middleware(__dirname + '/public'));
app.use(express.static(path.join(__dirname, 'public')));
app.post('/handshake', cookieMiddleware , handshake.token);
app.get('/', routes.index);
app.get('/users', user.list);


 var server = http.createServer(app).listen(app.get('port'), function(){
  console.log('Express server listening on port ' + app.get('port'));
});

io = io.listen(server);

io.sockets.on('connection', function (socket) {
      socket.emit('news', { hello: 'world' });
      socket.on('my other event', function (data) {
        console.log(data);
      });
    });

handshake.js 处理程序

exports.token = function(req, res){
    req.body.title = 'Payment Portal';
    res.render('payment_init', req.body);
};
4

1 回答 1

0

You are checking for a cookie named cokkieName, but the cookie you are setting has the name price.

Try changing this to:

var cookie = req.cookies.price;

cookie should now contain your cookie value.

于 2013-04-26T16:47:24.090 回答