我有这个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
答案 0 :(得分:0)
我修好了。看来就行了
res.writeHead(200, {"Content-Length": Buffer.byteLength(req.body)});
不允许它发布数据。我尝试删除它并且upsert工作。
但是,我想知道为什么要删除它就可以了。我认为Content-Length是必要的,因为它指定了身体的长度。