![](/img/trans.png)
[英]Getting a ValidationError in mongoose when trying to write new or updates to my mongoDB on mlab
[英]Getting an error when trying to connect to MongoDB on Mlab
我在MLab上创建了一个免费的数据库,并在node中建立了连接,但是当我尝试插入时出现错误:
错误:没有授权在Capina上执行命令{插入:\\“产品\\”,文档:[{_id:ObjectId('5b255d56a7be644ca873631e'),名称:\\“טארלטמלוחאישי\\”,priceNoVAT:0.97,priceVAT:1.05,quantumPerUnit :150,单位:\\“ארגז\\”,总价:130,__ v:0}],订购:true}“
这是连接代码:
//works fine, no error here
mongoose
.connect(
"mongodb://" +
process.env.MONGO_USERNAME +
process.env.MONGO_PWD +
"@ds161620.mlab.com:61620/" + process.env.DB_NAME
)
.catch(err => {
console.error(err);
});
这是模型:
const mongoose = require("mongoose");
const productSchema = mongoose.Schema({
_id: mongoose.Schema.Types.ObjectId,
name: { type: String, required: true },
priceNoVAT: Number,
priceVAT: Number,
quantityPerUnit: Number,
unit: String,
totalPrice: Number
});
module.exports = mongoose.model("Product", productSchema);
这是我试图调用并得到错误的测试路线:
router.post("/", (req, res) => {
const product = new Product({
_id: new mongoose.Types.ObjectId(),
name: "טארלט מלוח אישי",
priceNoVAT: 0.97,
priceVAT: 1.05,
quantityPerUnit: 150,
unit: "ארגז",
totalPrice: 130
});
product
.save()
.then(result => {
res.json({ message: "Product Saved" });
})
.catch(err => {
console.log(err);
res.json({ message: "Error:" + err.message });
});
});
用户名/密码定义正确,当我登录时,我看到我得到了正确的值,所以我真的不确定自己在做什么错吗?
终于明白了,这是一个愚蠢的错误,但是它可能发生在其他人身上,所以我在这里发布答案:
我忘记在用户名和密码之间添加“:”,因此:
"mongodb://" +
process.env.MONGO_USERNAME +
process.env.MONGO_PWD +
"@ds161620.mlab.com:61620/" + process.env.DB_NAME
实际上应该是:
"mongodb://" +
process.env.MONGO_USERNAME +
":" +
process.env.MONGO_PWD +
"@ds161620.mlab.com:61620/" + process.env.DB_NAME
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.