来自客户端表达nodejs的重复请求

时间:2013-05-07 15:39:49

标签: javascript node.js express

我的应用无法解决问题

首先是我的应用:

nodejs 0.8.14 表达3.1 护照本地0.1

问题是当我在护照会话中登录时,客户端请求页面两次......

我发现因为我在网址中添加了一个请求var

这在我的路由器中

exports.index=function(req,res)
{
    console.log('success: '+req.url);
    var sesion_usuario=validate(req.params.code_user);//if not valid return null
    if(sesion_usuario){
        res.render('logged',{title:'Hello'+sesion_usuario})

这在我的浏览器中

http://localhost:8000/YOGE7419

这在我的应用

app.get('/:code_user',routes.index);

这就是我在提示中收到的内容

success: /YOGE7419
success: /YOGE7419
DEBUG: validate error: maxlength not match

和此

中的网址转换
http://localhost:8000/YOGE7419#sthash.zp1bOY2d.dpbs

为什么?什么是第一次和第二次请求之间发生的? TNX

APP配置

app.configure(function()
{
    app.use(express.favicon(__dirname + '/public/images/favicon.png')); 
    app.set('port',  8000 || process.env.PORT);
    app.set('views', __dirname + '/views');
    app.set('view engine', 'jade');
    app.set('view options',{layout:false});
    //app.use(express.logger('dev'));
    app.use(express.bodyParser({uploadDir:'./public/uploads/'}));
    app.use(express.cookieParser('nomatherwhatdoyoudobatman'));
    app.use(express.session());
    app.use(passport.initialize());
    app.use(passport.session());
    //app.use(express.methodOverride());
    app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
    app.use(function(req, res, next){
        res.render('404.jade',
            {
                title: "404 - Page Not Found",
                showFullNav: false,
                status: 404,
                url: req.url
            });
    });
});

2 个答案:

答案 0 :(得分:1)

第一个请求是由浏览器自动发出的,它请求favicon.ico,当然,第二个请求是URL(你的URl)。

进一步参考

http://net.tutsplus.com/tutorials/javascript-ajax/node-js-for-beginners/

答案 1 :(得分:0)

如果express重定向了浏览器,那么如果重定向未完成,浏览器将发送重复的请求(以我的经验,这是5秒钟后)。

通过向重定向请求添加超时,我能够避免重复请求:

app.get('/path2', function( req, res ) {
    req.connection.setTimeout( 1000 * 60 * 10 ); // ten minutes
    console.log('path2');
});

有关详细讨论,请在GitHub Link上阅读。