使用Node JS连接到Atlas MongoDB时出错

时间:2019-10-31 07:58:55

标签: node.js mongodb mongodb-atlas

我正在尝试使用节点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('/')
       })
    })
})

CMD屏幕截图 enter image description here

2 个答案:

答案 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";