意外的输入错误结束

时间:2014-02-28 15:27:14

标签: javascript node.js mongodb express

我有这个nodejs应用程序,我所做的一个调用是一个upsert调用,它将请求体提供给mongodb。如果请求体存在于mongo中,请更新它,否则插入它。插入部分正常工作,但是我遇到了upsert部分的问题。我的请求正在由我编写的C#应用​​程序生成。

好的,所以当我更新时,我需要使用$ addToSet和$ each命令,因为我将元素添加到mongo文档中的数组中。

这是一个示例请求正文(这是一个POST),这是发送到我的nodejs app的内容:

{
    "$addToSet": {
        "Data": {
            "$each": [
                {"ID":"10","RandNum":"45"},
                {"ID":"11","RandNum":"1"},
                {"ID":"12","RandNum":"3"}
            ]
        }
     }
}

文档的格式如下:mongo:

{
    "Timestamp": "timestamp",
    "Id": "12345",
    "Header": {
        "Name": "Name",
        "Query": "SELECT * FROM test"
    },
    "Data": [
        {
            "ID": "1",
            "RandNum": "34"
        }, {
            "ID": "4",
            "RandNum": "23"
        }
    ]
}

我只对插入“Data”数组感兴趣,所以我使用的是$ addToSet和$ each运算符。

这是我在nodejs app上的upsert调用,实际的函数有很多代码,所以我只是把upsert部分:

var db = require('../db.js');
var ind = require('./index.js');
var mongo = require('mongodb').MongoClient;

exports.upsert = function(req, res) {
    var token = req.params.token;
    var app = req.params.applicationId;
    var dataObject = {
        "Status": 1,
        "DataObject": {},
        "UserFriendlyErrorMessage": "",
        "DeveloperErrorMessage": ""
    };

    // set response header
    res.writeHead(200, {"Content-Type": "application/json"});
    res.writeHead(200, {"Content-Length": Buffer.byteLength(req.body)});

    var upsertDatabase = mongo.connect(ind.mongoLoc + databaseName, function(err, newDb) {
        if(err)
            throw err;
        var upsertCollection = newDb.collection(collectionName);
        if(newDb) {
            if(req.query.query) {
                // UPSERT
                try {
                    var json = JSON.parse(req.query.query);
                    upsertCollection.update(json, req.body, {upsert: true, multi: false}, function(err, records) {
                        if(err)
                            throw err;
                        console.log("Data updated");
                    });
                } catch(e) {
                    dataObject["DataObject"] = null;
                    dataObject["UserFriendlyErrorMessage"] = "Could not update";
                    dataObject["DeveloperErrorMessage"] = e;
                    res.end(JSON.stringify(dataObject, 0, 4));
                    console.log(e);
                }
            } else {
                 // INSERT
                 upsertCollection.insert(req.body, function(err, records) {
                    if(err)
                        throw err;
                    console.log("Data inserted");
                 });
             }
             dataObject["Status"] = 0;
             dataObject["DataObject"] = null;
             res.end(JSON.stringify(dataObject, 0, 4));
         } else {
            // could not connect to database
            dataObject["DataObject"] = null;
            dataObject["UserFriendlyErrorMessage"] = "Could not connect to database";
            dataObject["DeveloperErrorMessage"] = "ERROR: Could not connect to database";
            res.end(JSON.stringify(dataObject, 0, 4));
        }
    });
};

在这个函数中,我正在测试该文档是否存在,然后如果它存在则将其置位。这是我关注的部分。 dataObject是我返回给用户以显示错误/成功的内容。

当我将数据发布到此调用时,我收到此错误(我正在Fiddler中查看POST调用):

HTTP/1.1 504 Fiddler - Receive Failure
Date: Fri, 28 Feb 2014 15:30:39 GMT
Content-Type: text/html; charset=UTF-8
Connection: close
Cache-Control: no-cache, must-revalidate
Timestamp: 10:30:39.535

[Fiddler] ReadResponse() failed: The server did not return a response for this request.Server returned 0 bytes

Content-Type应该是application / json

1 个答案:

答案 0 :(得分:0)

我修好了。看来就行了

res.writeHead(200, {"Content-Length": Buffer.byteLength(req.body)});

不允许它发布数据。我尝试删除它并且upsert工作。

但是,我想知道为什么要删除它就可以了。我认为Content-Length是必要的,因为它指定了身体的长度。