私はMEANスタックをかなり新しくしているので、おそらく私は信じられないほどばかげたことをしています。Mongooseネストされたスキーマ検証エラー
私はいくつかの定義されたスキーマ(BlogEntry、ForumPost)を持っていますので、コードの重複を避けるためにコメントスキーマを独自のファイルに移動しました。
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var BlogEntry = new Schema({
title: String,
thumbnailUrl: String,
content: String,
comments: [
{
type: Schema.Types.ObjectId,
ref: 'Comment'
}
]
}, {
timestamps: true
});
var Blog = new Schema({
createdBy: {
type: Schema.Types.ObjectId,
ref: 'User'
},
name: {
type: String,
required: true
},
headerImageUrl: String,
description: String,
blogEntries: [BlogEntry]
}, {
timestamps: true
});
module.exports = mongoose.model('Blog', Blog);
とコメントスキーマがcomment.jsに含まれています:
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var Comment = new Schema({
commentText: {
type: String,
required: true
},
postedBy: {
type: Schema.Types.ObjectId,
ref: 'User'
},
parentComment: {
type: Schema.Types.ObjectId,
ref: 'Comment'
}
}, {
timestamps: true
});
module.exports = mongoose.model('Comment', Comment);
私のルータだけBlogEntryの例では、私は私のblog.jsモデルで以下のいる探し
ブログの情報を処理するため、次のものが含まれます
var express = require('express');
var bodyParser = require('body-parser');
var mongoose = require('mongoose');
var Blog = require('../models/blog');
var Verify = require('./verify');
var blogRouter = express.Router();
blogRouter.use(bodyParser.json());
blogRouter.route('/')
.get(function(req, res, next) {
Blog.find(req.query)
.populate('createdBy')
.exec(function(err, blog) {
if(err) return next(err);
res.json(blog);
});
})
.post(Verify.verifyOrdinaryUser, function(req, res, next) {
req.body.createdBy = req.decoded._id;
Blog.create(req.body, function(err, blog) {
if(err) return next(err);
console.log("Blog created");
var id = blog._id;
res.writeHead(200, { 'Content-Type': 'text/plain'});
res.end('Added the blog with id: ' + id);
});
});
module.exports = blogRouter;
コメントスキーマがseparatであります私はcomment.jsファイルを取り除く場合は、しかし、
{
"name": "A Cheesemaker's Adventure",
"headerImageUrl": "images/cheeseAdven.png",
"description": "The story of a man's transformation from a miserable, downtrodden software engineer to a bouyant, joy-filled cheesemaker.",
"blogEntries" : [
{
"title": "I like cheese",
"content": "Here is my story...blah blah blah...",
"comments": [
{
"commentText": "Who's is this guy kidding!"
}
]
}
]
}
<!DOCTYPE html><html><head><title></title><link rel="stylesheet" href="/stylesheets/style.css"></head><body><h1>Blog validation failed</h1><h2></h2><pre>ValidationError: Blog validation failed
at MongooseError.ValidationError (C:\Development\hcj-express\node_modules\mongoose\lib\error\validation.js:22:11)
at model.Document.invalidate (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:1410:32)
at EmbeddedDocument.invalidate (C:\Development\hcj-express\node_modules\mongoose\lib\types\embedded.js:190:19)
at EmbeddedDocument.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:703:10)
at EmbeddedDocument.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:548:18)
at EmbeddedDocument.Document (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:67:10)
at new EmbeddedDocument (C:\Development\hcj-express\node_modules\mongoose\lib\types\embedded.js:30:12)
at EmbeddedDocument (C:\Development\hcj-express\node_modules\mongoose\lib\schema\documentarray.js:27:17)
at DocumentArray.cast (C:\Development\hcj-express\node_modules\mongoose\lib\schema\documentarray.js:254:22)
at DocumentArray.SchemaType.applySetters (C:\Development\hcj-express\node_modules\mongoose\lib\schematype.js:628:12)
at model.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:695:18)
at model.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:548:18)
at model.Document (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:67:10)
at model.Model (C:\Development\hcj-express\node_modules\mongoose\lib\model.js:41:12)
at new model (C:\Development\hcj-express\node_modules\mongoose\lib\model.js:3175:11)
at C:\Development\hcj-express\node_modules\mongoose\lib\model.js:1847:51</pre></body></html>
などのように、blog.jsファイルにコメントスキーマを移動:電子ファイル、と私は、私は、検証エラーを次のリクエストGET、POST上記のメッセージと全く同じメッセージを投稿することができますが、検証エラーは消え、データを正常に投稿します。
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var Comment = new Schema({
commentText: {
type: String,
required: true
},
postedBy: {
type: Schema.Types.ObjectId,
ref: 'User'
},
parentComment: {
type: Schema.Types.ObjectId,
ref: 'Comment'
}
}, {
timestamps: true
});
var BlogEntry = new Schema({
title: String,
thumbnailUrl: String,
content: String,
comments: [Comment]
}, {
timestamps: true
});
var Blog = new Schema({
createdBy: {
type: Schema.Types.ObjectId,
ref: 'User'
},
name: {
type: String,
required: true
},
headerImageUrl: String,
description: String,
blogEntries: [BlogEntry]
}, {
timestamps: true
});
module.exports = mongoose.model('Blog', Blog);
Sooo ...私はここで間違っていますか?
上記の変更を行い、サーバーに展開しても同じエラーが発生します。興味深いことに、Userへのネストされた参照は、それが別のファイルにあってもうまく動作し、このスキーマファイルに明示的に必要とされていません。 –
コード内の別のポイントでUserを使用している場合は(確かにverifyOrdinaryUser関数に)その後、以前の 'require'がそれをmongooseキャッシュに追加しました。 '' 'require( './ comment.js')' ''のままにして、 '' 'コメントを変更しよう:[Comment]' '' '' 'コメント:[{ type:Schema.Types。 ObjectId、 ref: 'Comment' }] '' ' –
@Rafaelには同意しますが、これはcomment.jsの最初の使用ですので、requireステートメントに含める必要があります。私はコメント:[Comment]とコメント:[{type:Schema.Types.ObjectId、ref: 'Comment'}] 'の両方を使用しようとしましたが、どちらの場合も同じエラーが発生します。 –