我的应用无法解决问题
首先是我的应用:
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
});
});
});
答案 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上阅读。