ExpressJS中POST方法的变量会话范围

时间:2013-10-10 12:16:51

标签: javascript node.js express

带有express.js的node.js中POST方法中的req.session.myvar ='a value'似乎只有一个本地范围。我无法从其他方法获取req.session.myvar值。但是,如果我将值保存在GET方法中,则范围似乎具有全局范围。我需要POST方法做同样的事。

var express  = require('express'),
port     = 3000;
var app = express();

app.use(express.bodyParser());
app.use(express.cookieParser(''));
app.use(express.session({ secret: 'secret'}));
app.use(express.static(__dirname + '/public/'));
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');

app.post('/create', function(req, res) {
   req.session.firstName = 'jhon';
   console.log(req.session);
});


app.get('/create', function(req, res) {
   console.log(req.session);
   req.session.lastName = 'Doe';
   res.render('create');
});


app.post('/create_occur', function(req, res) {
   console.log('/create_occur');
   console.log(req.session);
});

app.listen(port);
console.log('Listening on port ' + port);

这是我用来做测试的简单的.ejs。

<!DOCTYPE html>
<html>
    <head>
        <script type="text/javascript" src="/js/jquery-1.9.1.min.js"></script>
        <script type="text/javascript" src="/js/socket.io.js"></script>
    </head>

    <body>        
        <section>
            <input type="text" id="title" placeholder="Title">
            <input type="submit" id="enviar" value="Enviar">
        </section>       
        <section>
            <input type="text" id="name" placeholder="Nombre">
            <input type="submit" id="nombre" value="Nombre">
        </section>
        <script>
            $(document).ready(function() {                

                $("#enviar").click(function() {
                    var title = $('#title').val();

                    $.ajax({
                        url:  '/create',
                        type: 'POST',
                        dataType: 'json',
                        data: {'title': title}
                    });
                });               

                $("#nombre").click(function() {
                    var name = $('#name').val();

                    $.ajax({
                        url:  '/create_occur',
                        type: 'POST',
                        dataType: 'json',
                        data: {'title': name}
                    });
                });
            });
        </script>
    </body>
</html>

请帮帮我,我不明白为什么会这样。我在博客和视频中看到了几个类似的例子,他们这样做并且有效。

THX。

1 个答案:

答案 0 :(得分:0)

好的,我终于弄明白了!!这是一个愚蠢的问题/被遗忘。我要添加一行来回应请求:

res.end();

或者:

res.redirect('/');
再见,我希望这会有所帮助。