我遇到了 Mongoose .save 方法的问题。永远不会创建数据库,也不会保存数据,也不会引发任何错误。我已经用尽了谷歌和 stackoverflow 来寻找类似的建议,但没有运气,所以把它开放给任何可以帮助我的人!
我的 POST 请求是通过以下方式发出的:
export function registerUser({ email }) {
return function(dispatch) {
axios.post(`${API_URL}/auth/register`, { email })
.then(response => {
dispatch({ type: AUTH_USER });
})
.catch((error) => {
errorHandler(dispatch, error.response, AUTH_ERROR)
});
}
}
我发出了几个 POST 请求,并且都使用 sever config: 从 API 返回了成功状态{'database': 'mongodb://localhost/practicedb', 'port': process.env.PORT || 3000}
,但是数据永远不会被保存,并且数据库(practicedb)没有显示在终端上。
使用mongoose模式(user.js):
var UserSchema = new Schema({
email: {
type: String,
lowercase: true,
unique: true,
required: true
},
})
API 控制器
接收电子邮件字符串 POST 请求,然后如果在文本字段中没有输入任何内容,它会发回 422 错误,并且在内部User.findOne
,如果电子邮件已经存在于数据库中,则它会抛出 422 错误,如果不存在,则user.save
执行将其保存在数据库中。但是 .save 不能正常工作,甚至没有创建数据库。
"use strict";
const User = require('../models/user')
exports.register = function(req, res, next) {
const email = req.body.email;
if(!email) {
return res.status(422).send({ error: 'You must enter an email address.'})
}
User.findOne({ email: email }, function(err, existingUser) {
if(err) { return next(err); }
if(existingUser) {
return res.status(422).send({ error: 'That email address is already in use.'})
}
let user = new User({
email: email,
})
user.save(function(err, user) {
if(err) { return next(err); }
res.status(201).json({
user: user,
})
})
})
}
编辑
我为 API 控制器尝试了更广泛的控制台日志记录,一旦触发,看起来它没有执行任何操作并跳到末尾,但随后它又恢复并进入 User.findOne 和 user.save,但看起来像用户.save 不起作用。
难道是服务器没有正确连接到数据库?有没有办法确定是否正在使用 MongoDB 方法?
也尝试过快速日志记录:
这是服务器的设置方式:
const express = require('express'),
app = express(),
logger = require('morgan'),
config = require('./config/main'),
mongoose = require('mongoose'),
bodyParser = require('body-parser'),
router = require('./router');
mongoose.Promise = global.Promise;
mongoose.connect(config.database);
const server = app.listen(config.port);
console.log('Your server is running on port ' + config.port + '.');
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.use(logger('dev'));
app.use(function(req, res, next) {
res.header("Access-Control-Allow-Origin", "http://localhost:8080");
res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS');
res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization, Access-Control-Allow-Credentials");
res.header("Access-Control-Allow-Credentials", "true");
next();
})
router(app);
编辑 2