Express.jsとmongoosejsを使ってブログのウェブサイトを構築しています。記事には1つ以上のカテゴリがあります。新しい記事を作成すると、エラーが発生します。
{ [CastError: Cast to ObjectId failed for value "[object Object]" at path "categories"]
message: 'Cast to ObjectId failed for value "[object Object]" at path "categories"',
name: 'CastError',
type: 'ObjectId',
value: [ [object Object] ],
path: 'categories' }
誰かが私を助けることができますか?関連コードは次のとおりです。
このように定義されたArticle
モデル:
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
var ArticleSchema = new Schema({
created: { type: Date, default: Date.now},
title: String,
content: String,
summary: String,
categories: [{
type: Schema.ObjectId,
ref: 'Category' }]
});
mongoose.model('Article', ArticleSchema);
そして、次のように定義されたCategory
モデル:
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
var CategorySchema = new Schema({
parent: {
type: Schema.ObjectId,
},
name: String,
subs: [CategorySchema]
});
mongoose.model('Category', CategorySchema);
新しい記事を作成して次のように保存すると:
exports.create = function(req, res) {
console.log(req.body);
var article = new Article(req.body);
article.user = req.user;
console.log(article);
article.save(function(err) {
if (err) {
console.log(err);
return res.jsonp(500, {
error: 'Cannot save the article'
});
}
res.jsonp(article);
});
};
create
関数を呼び出すと、console.log()の出力は次のようになります。
// console.log(req.body);
{ title: 'This is title',
content: '<p>content here</p>',
categories:
[ { _id: '53c934bbf299ab241a6e0524',
name: '1111',
parent: '53c934b5f299ab241a6e0523',
__v: 0,
subs: [],
sort: 1 } ],
updated: [ 1405697477413 ] }
// console.log(article);
{
title: 'This is title',
content: '<p>content here</p>',
_id: 53c93dc5b1c3b8e80cb4936b,
categories: [],
created: Fri Jul 18 2014 23:31:17 GMT+0800 (中国标准时间) }
// console.log(err);
{ [CastError: Cast to ObjectId failed for value "[object Object]" at path "categories"]
message: 'Cast to ObjectId failed for value "[object Object]" at path "categories"',
name: 'CastError',
type: 'ObjectId',
value: [ [object Object] ],
path: 'categories' }
私はたくさんググったが、運がなかった。私を助けてください!
更新: Gergoの回答に感謝します。しかし、almosetと同じコードで既存の記事を更新すると、問題なく動作します。どうして?コードは次のとおりです。
var mongoose = require('mongoose'),
Category = mongoose.model('Category'),
_ = require('lodash');
exports.update = function(req, res) {
console.log(req.body);
var article = req.article;
article = _.extend(article, req.body);
console.log(article);
article.save(function(err) {
if (err) {
return res.jsonp(500, {
error: 'Cannot update the article'
});
}
res.jsonp(article);
});
};
次のような出力:
// console.log(req.body);
{ _id: '53ca42f418bfb23c1e04df02',
summary: 'tttt',
title: 'tt',
content: '<p>tttt</p>',
__v: 2,
categories: [ { _id: '53c934bbf299ab241a6e0524', name: '1111' } ],
created: '2014-07-19T10:05:40.183Z'
}
// console.log(article);
{ _id: 53ca42f418bfb23c1e04df02,
title: 'tt',
content: '<p>tttt</p>',
__v: 2,
categories: [ { _id: 53c934bbf299ab241a6e0524, name: '1111', subs: [], sort: 0
} ],
created: Sat Jul 19 2014 18:05:40 GMT+0800 (中国标准时间)
}
これは問題なく動作します。
記事のスキーマでは、ObjectIdの配列が必要です。
var ArticleSchema = new Schema({
...
categories: [{
type: Schema.ObjectId,
ref: 'Category' }]
});
ただし、req.body
にはカテゴリオブジェクトが含まれています。
categories:
[ { _id: '53c934bbf299ab241a6e0524',
name: '1111',
parent: '53c934b5f299ab241a6e0523',
__v: 0,
subs: [],
sort: 1 } ]
また、MongooseはカテゴリオブジェクトをObjectIdに変換できません。これがエラーが発生する理由です。 req.body
のcategories
にIDのみが含まれていることを確認してください。
{ title: 'This is title',
content: '<p>content here</p>',
categories: [ '53c934bbf299ab241a6e0524' ],
updated: [ 1405697477413 ] }
カテゴリのデータ型としてmongoose.Schema.Types.Mixedを使用してください。データ配列の保存でも同じ問題が発生しました。わたしにはできる。
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
var ArticleSchema = new Schema({
created: { type: Date, default: Date.now},
title: String,
content: String,
summary: String,
categories: [{type: Schema.Types.Mixed }]
});
mongoose.model('Article', ArticleSchema);