我想在此前言,我已经在这里阅读了几篇有关此问题的帖子。
我有一个node / express / mongo应用程序,其中包含以下内容:
app.js:
var express = require('express')
var bodyParser = require('body-parser')
var cors = require('cors')
var morgan = require('morgan')
var mongoose = require('mongoose')
var passport = require('passport')
var app = express()
// MongoDB Setup
var configDB = require('./config/database.js')
mongoose.connect(configDB.url)
app.use(morgan('combined'))
app.use(bodyParser.json())
// Check security with this
app.use(cors())
// load our routes and pass in our app and fully configured passport
require('./routes')(app)
app.listen(process.env.PORT || 8081)
console.log('We are up and running, captain.')
routes.js
const AuthenticationController = require('./controllers/AuthenticationController')
module.exports = (app) => {
app.post('/register', AuthenticationController.register)
}
我的mongo架构文件Account.js:
const mongoose = require('mongoose')
const bcrypt = require('bcrypt-nodejs')
const Schema = mongoose.Schema
var accountSchema = new Schema({
email: String,
password: String,
likesPerDay: { type: Number, min: 0, max: 250 },
followPerDay: { type: Number, min: 0, max: 250 },
unfollowPerDay: { type: Number, min: 0, max: 250 },
commentsPerDay: { type: Number, min: 0, max: 250 },
comment: String,
hashtags: [String]
})
// methods ======================
// generating a hash. We hash password within user model, before it saves to DB.
accountSchema.methods.generateHash = function (password) {
return bcrypt.hashSync(password, bcrypt.genSaltSync(8), null)
}
// checking if password is valid
accountSchema.methods.validPassword = function (password) {
return bcrypt.compareSync(password, this.local.password)
}
// create the model for users and expose it to our app
module.exports = mongoose.model('Account', accountSchema)
最后我的控制器文件AuthenticationController.js
const Account = require('../models/Account.js')
// var bodyParser = require('body-parser')
module.exports = {
register (req, res) {
Account.findOne({email: req.body.id}, function (err, account) {
if (err) {
console.log('Could not regster user')
throw err
}
if (account) {
console.log('account already exists')
} else {
Account.insertOne({email: req.body.email, password: req.body.password}, function (err, res) {
if (err) {
console.log('could not insert')
throw err
}
console.log('inserted account')
Account.close()
})
}
})
}
}
当我调用Account.insertOne
函数时,我的 AuthenticationController 文件中出现错误。
我收到错误
TypeError:Account.insertOne不是函数
现在堆栈上的几个帖子已经建议我确保从我的模型类中导出模型,我正在做,这将解决这个问题。它很奇怪,因为findOne
方法看起来很好,但是当我调用insertOne
时,我遇到了问题。
我在这里错过了什么吗?
答案 0 :(得分:6)
Mongoose模型没有insertOne
方法。请改用create
方法:
Account.create({email: req.body.email, password: req.body.password}, function (err, doc) {
答案 1 :(得分:1)
The Mongoose docs显示如何创建文档:
通过 localStorage
:
Account.create()
或实例化并Account.create({email: req.body.email, password: req.body.password}, function (err, res) {
// ...
})
该帐户:
save()
答案 2 :(得分:0)
修改强>
从mongoose documentation起,请尝试使用
Account.create({ ...params ... }, function (err, small) {
if (err) return handleError(err);
// saved!
})
答案 3 :(得分:0)
insertOne
命令在mongoose中不可用。如果要使用insertOne
命令,则需要使用bulk命令将此命令发送到MongoDB服务器。像下面的东西。我希望这有效。
Account.bulkWrite([
{
insertOne: {
document: {email: req.body.email, password: req.body.password}
}
}
}]