2013-06-04 66 views
4

我有一个小型的node.js应用程序使用express框架,但由于某种原因,我无法让我的应用程序响应POST请求。在服务器日志中,我只是简单地获得“POST/404 5ms”,我找不到原因。Node.js express POST 404ing

编辑:澄清 - 我的问题是app.post似乎并没有被做任何事情

编辑2:我不知怎么设法解决这个问题,昨晚,但现在我不能弄清楚什么点我修好了。

Node.js的服务器代码:

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

var app = express(); 

// all environments 
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.methodOverride()); 
app.use(express.cookieParser('chocolatechip')); 
app.use(express.session()); 
app.use(app.router); 
app.use(express.static(path.join(__dirname, 'public'))); 


// development only 
if ('development' == app.get('env')) { 
    app.use(express.errorHandler()); 
} 

//pages 
//Landing page 
app.get('/', routes.index); 
app.post('/test',function(req,res){ 
    console.log(req.body); 
    res.send("received post"); 
}); 
//return list containing users 
//app.post('/users', user.list); 
//return requested user 
app.get('/users/:id', user.get); 
//app.post('/users/login', user.login); 


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

在实际的网页,我有以下的javascript代码:

var login = $('#login'); 
    var page = $('#page'); 
    var register = $('#register'); 
    var userField = login.find('.user'); 
    var passField = login.find('.pass'); 
    var confPassField = login.find('.confpass'); 
    var form = $('.logform'); 
    $('#formbutton').on('click',function(){ 
    if(register.hasClass('hidden')){ 
     login.addClass('hidden'); 
     confPassField.val(''); 
     var logDat = JSON.stringify(form.serializeArray); 
     userField.val(''); 
     passField.val(''); 
     page.html("Login form submitted"); 
     $.post(
     form.attr("action"), 
     {test:"test"}, 
     function(data){ 
      alert("Response: "+data) 
     } 
    ); 

    } 

回答

9

如果您要发布帖子/为你的日志说,你是 “POST/404 5ms的”,你需要更改以下行:

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

app.all('/', routes.index); 

这将允许GET或POST到该路线。如果您只发布到该路线,您也可以使用app.post()。希望这可以帮助。

文档浏览:http://expressjs.com/api.html#app.all

+0

好吧,这不是我的问题的答案,因为我已经使用app.post(),并且它不工作。这就是我的问题。 – LucienK

+0

您在“/ test”而不是“/”使用app.post。更彻底地阅读我的答案。 – thomallen

+0

我在说我是发布/测试,而不是/。我得到它的工作,这不是问题。为了让它在昨晚工作,现在我不记得我做了哪些改变。当我累了的时候,我好像有一个问题提交和标记修复... – LucienK

2

确保 'form.attr( “行动”)' 是获得正确的URL。看起来你的表单发布到索引页面而不是'/ test'。也许这应该改为$('form').attr("action")