我正在尝试使用节点js连接到Atlas mongo数据库。但是遇到错误TypeError: Cannot read property 'db' of null
时,我已经在地图集上创建了集群,并授予了用户 aayushg 的完整权限,还创建了一个db'test'
index.js
const express = require('express')
const bodyParser= require('body-parser')
const app = express()
app.use(bodyParser.urlencoded({extended: true}))
const MongoClient = require('mongodb').MongoClient;
// replace the uri string with your connection string.
const url = "mongodb+srv://aayushg:<aayushg18>@cluster0-fatp8.mongodb.net/test?retryWrites=true&w=majority";
const client = new MongoClient(url, { useNewUrlParser: true });
client.connect((err, database) => {
db = database.db("test")
app.listen(3000, function () {
})
app.get('/', (req, res) => {
//res.send('PDP')
res.sendFile(__dirname + '/index.html')
})
app.post('/quotes', (req, res) => {
db.collection('devices').save(req.body, (err, result) => {
if (err) return console.log(err)
console.log('saved to database')
res.redirect('/')
})
})
})
答案 0 :(得分:3)
因此,该错误与您在if(err) throw err
的帮助下提供的凭据有关,您可以看到该错误与凭据有关。现在,您必须添加正确的凭据才能正常工作。您使用的是<aayushg18>
而不是aayushg18
谢谢。
答案 1 :(得分:1)
我有你的问题。您的连接uri格式不正确。输入密码时,请勿使用<>符号。将<aayushg18>
替换为aayushg18
,如下所示:
const uri = "mongodb+srv://aayushg:aayushg18@cluster0-fatp8.mongodb.net/test?retryWrites=true&w=majority";