2

我正在尝试在使用 ajax 插入数据库之前进行身份验证

$('#button').click(function () {       
  $.post('/db/', { 
   stuff: { "foo" : "bar"}
  }, callback, "json");
});

这是我的 node.js 代码:

server.get('/', function(req,res){
console.log(res);
  res.render('index.ejs', {
    locals : { 
              header: '#Header#'
             ,footer: '#Footer#'
             ,title : 'Page Title'
             ,description: 'Page Description'
             ,author: 'Your Name'
             ,analyticssiteid: 'XXXXXXX' 
            }
  });
});

^^ 这部分工作正常。它来自样板文件,我可以去 localhost 并查看首页。

下一部分应该是 mongo 插入发生的地方。这给了我一个404。

server.on('/db/', function(req,res){
    console.log(req);
    console.log(res);
    var db = new mongo.Db( 'dbname' , new mongo.Server( 'localhost', 20003, {}), {});   
    db.open(function (err) {
        db.collection('testCollection', function (err, collection) {
            collection.insert(res.stuff);
        });
    });
});

我想要做的是将对象stuff插入到 testCollection 中。

现在我在 /db/ 上得到 404

我确信这是非常错误的。我不认为我应该使用 server.on,server.get 也不起作用。请指教,谢谢。

4

3 回答 3

6

您必须使用server.post,因为您正在通过 jQuery进行POST请求。

server.on将向服务器添加一个事件侦听器,在这种情况下,用于不存在的/db/事件,它永远不会被任何东西触发。

请花点时间阅读 express.js指南,Node.js API 文档也可能会派上用场。

于 2011-01-14T22:40:45.177 回答
2

由于您期待一个帖子,因此您的 /db/ 处理程序应该在一个server.post方法中定义。您收到 404,因为服务器没有为 POST 和 /db/ 的组合定义路由。

于 2011-01-14T22:42:34.357 回答
1

您还应该对数据库连接进行身份验证,并且不应该在每次请求时重新连接到数据库

var db = new mongo.Db( 'dbname' , new mongo.Server( 'localhost', 20003, {}), {});
db.authenticate(user, password, function({ // callback }));

server.post('/db/', function(req,res){
  db.open(function (err) {
    db.collection('testCollection', function (err, collection) {
      collection.insert(. . .);
    });
  });
});
于 2011-01-14T22:47:45.237 回答