首页 > 解决方案 > 我收到此错误 MongoClient 必须连接才能执行此操作

问题描述

我的控制台错误

[nodemon] restarting due to changes...
[nodemon] starting `node server.js`
Listening on port 3300
D:\program files\realtime-pizza-app-node-express-mongo-master\node_modules\mongodb\lib\utils.js:391
    throw new error_1.MongoNotConnectedError('MongoClient must be connected to perform this operation');
          ^

MongoNotConnectedError: MongoClient must be connected to perform this operation
    at Object.getTopology (D:\program files\realtime-pizza-app-node-express-mongo-master\node_modules\mongodb\lib\utils.js:391:11)
    at Collection.createIndex (D:\program files\realtime-pizza-app-node-express-mongo-master\node_modules\mongodb\lib\collection.js:258:61)
    at MongoStore.setAutoRemove (D:\program files\realtime-pizza-app-node-express-mongo-master\node_modules\connect-mongo\build\main\lib\MongoStore.js:147:35)
    at D:\program files\realtime-pizza-app-node-express-mongo-master\node_modules\connect-mongo\build\main\lib\MongoStore.js:128:24
    at processTicksAndRejections (node:internal/process/task_queues:96:5)
[nodemon] app crashed - waiting for file changes before starting...

这是我的 server.js 文件,我不知道里面有什么问题

我的 server.js 文件

require('dotenv').config()
const express = require('express')
const app = express()
const ejs = require('ejs')
const path = require('path')
const expressLayout = require('express-ejs-layouts')
const PORT = process.env.PORT || 3300
const mongoose = require('mongoose')
const session = require('express-session')
const flash = require('express-flash')
const MongoDbStore = require('connect-mongo')
const passport = require('passport')
const Emitter = require('events')

// Database connection
mongoose.Promise = global.Promise;
(async function(){
await mongoose.connect(process.env.MONGO_CONNECTION_URI, {  useNewUrlParser: true,
    useUnifiedTopology: true})
})();


// Session store
// const mongoStore = new MongoDbStore({
//                 client:connection.getClient(),
//                 collectionName: 'sessions'
//             })

// Event emitter
const eventEmitter = new Emitter()
app.set('eventEmitter', eventEmitter)

const clientPromise = Promise.resolve(mongoose.connection.getClient());
// clientPromise = new Promise(function (resolve, reject) {
//     resolve(mongoose.connection.getClient())
//     reject(new Error('MongoClient Error'))
//   })

// Session config
app.use(session({
    secret: process.env.COOKIE_SECRET,
    resave: false,
    store:MongoDbStore.create({
        client:mongoose.connection.getClient('process.env.MONGO_CONNECTION_URI') ,
        clientPromise,
        // mongoUrl:"process.env.MONGO_CONNECTION_URL"
    }),
    saveUninitialized: false,
    cookie: { maxAge: 1000 * 60 * 60 * 24 } // 24 hour
}))

// Passport config
const passportInit = require('./app/config/passport')
passportInit(passport)
app.use(passport.initialize())
app.use(passport.session())

app.use(flash())
// Assets
app.use(express.static('public'))
app.use(express.urlencoded({ extended: false }))
app.use(express.json())

// Global middleware
app.use((req, res, next) => {
    res.locals.session = req.session
    res.locals.user = req.user
    next()
})
// set Template engine
app.use(expressLayout)
app.set('views', path.join(__dirname, '/resources/views'))
app.set('view engine', 'ejs')

require('./routes/web')(app)
app.use((req, res) => {
    res.status(404).render('errors/404')
})

const server = app.listen(PORT , () => {
            console.log(`Listening on port ${PORT}`)
        })

// Socket

const io = require('socket.io')(server)
io.on('connection', (socket) => {
      // Join
      socket.on('join', (orderId) => {
        socket.join(orderId)
      })
})

eventEmitter.on('orderUpdated', (data) => {
    io.to(`order_${data.id}`).emit('orderUpdated', data)
})

eventEmitter.on('orderPlaced', (data) => {
    io.to('adminRoom').emit('orderPlaced', data)
})

我不知道为什么会收到此错误,并且我在任何地方都没有解决此错误,如果您对此错误有任何想法,请帮助我感谢您的帮助,谢谢您提前帮助我

标签: javascriptnode.jsmongodbexpressmongoose

解决方案


推荐阅读