node/express を使用して API を構築します。mongoDB を使用してコレクション内の配列を更新する際に問題が発生しています。コレクション ユーザーの useritems 配列に参照 ID を追加したいだけです。
ユーザーは次のようになります。
[
{
fbname: "name.name",
email: "name.name@hotmail.com",
username: "mr.name",
useritems: [ObjectId("51e101df2914931e7f000003"), ObjectId("51e101df2914931e7f000005"), ObjectId("51cd42ba9007d30000000001")]
}];
私のserver.jsで:
var express = require('express'),
item = require('./routes/items');
var app = express();
app.configure(function () {
app.use(express.logger('dev'));
app.use(express.bodyParser());
});
app.put('/users/:userId/item/:itemId/add', item.addUserItem);
クエリ:
exports.addUserItem = function(req, res) {
var user = req.params.userId;
var item = req.params.itemId;
console.log('Updating useritem for user: ' + user);
console.log("item: ", item);
db.collection('users', function(err, collection) {
collection.update({'_id':new BSON.ObjectID(user)}, {$addToSet: { useritems: item}});
});
}
curl で試してみると、何も起こらず、次のエラーが表示されます: (52) Empty reply from server, from curl
カール:
curl -i -X PUT -H 'Content-Type: applicatio/json' http://127.0.0.1:3000/users/51e6a1116074a10c9c000007/item/51e6a1116074a10c9c000006/add