A starter example tutorial for connecting ExpressJs to a Mongoose database hosted on MongoDB.
Prerequisites
Here's what you will need in order to get started:
- Setup a MongoDB account to host your database.
- We will continue on the simple starter Vue3/ExpressJS app from our prior post.
Getting Started
First, let's clone our prior Vue3/ExpressJS app and rename it. Â Run the following:
git clone [email protected]:Initial-Apps/vue3-express.git vue3-express-mongo
Now, let's move into our app and install our modules on our server
:
cd vue3-express-mongo/server
npm install
Next, let's start the server to make sure all is working. Â Run the following:
node server.js
Setting up MongoDB
Login to your MongoDB account: https://cloud.mongodb.com/
Select New Project
and name your project. You can add members if you like. Then click Create Project
.
Next, continue to Build a Database
.
data:image/s3,"s3://crabby-images/15bf4/15bf4a7d0c2a8a2d7420078cd6dfd5e569c6e9d1" alt=""
Select whatever plan you like and click create
.
Next, create a username and password for your database, and be sure to save this info.
data:image/s3,"s3://crabby-images/47c19/47c1994fd218b79d7b53310438fc66a706b57353" alt=""
Then, select connect from My Local Environment
(see below):
data:image/s3,"s3://crabby-images/19daa/19daa5593013f404d839af3a9e5ec7f005cbd253" alt=""
Finally, select Finish and Close
. Hooray, we've setup our database! 🤓
Connecting ExpressJs to our MongoDB
Now let's work on our server to connect ExpressJs to MongoDB. To do this, we'll work on our server middleware file server/server.js
. Let's open this file and get to work. Â
I'm adding the following code to server.js
just after defining our imported modules. I've added code comments as well.
require('dotenv').config(); // needed to read our environment variables
const mongoose = require('mongoose'); // We need the mongoose module
const connectString = process.env.MONGODB; // This holds our username and password, stored as a environment variable
mongoose.connect(connectString, { useNewUrlParser: true }).then(
() => {
console.log ('Succeeded connected to database');
},
err => {
console.log ('ERROR connecting to database: ' + err);
}
);
Here's what the above code does:
- Adds the
dotenv
module so that we can store our MongoDB username and password as an environment variable. Â This is preferred over placing this sensitive information directly in your code. - Adds the
mongoose
module for connecting to our MongoDB database - The
connectString
variable will hold our login credentials for MongoDB. Â We'll set this up next. - Finally, we add the connect script to connect to our DB.
Next, we have to setup our login and password for MongoDB as an environment variable. Â You do not want to ever share this file because it has sensitive login information. Â That said, I've created a example_env.txt
file in our github repo to provide template. Â
We make sure our environment credentials are hidden by opening your .gitignore
file, adding the following to the end of the file and save:
# env files
.env
Next, we'll get our connect string from MongoDB. You can find your connect string format on your MongoDB dashboard. Â Click connect
and then connect by Drivers.
data:image/s3,"s3://crabby-images/c9c93/c9c93acc2af50c9595b749086e76f08e7fce4c71" alt=""
We are going to add our key using mongoose
so we only need to pay attention to the Driver and the Connection String.
Select Node
for the Driver like so:
data:image/s3,"s3://crabby-images/3be87/3be872679dba21be26a1508a644eaaa832e2276f" alt=""
Then copy and paste your Connection String:
data:image/s3,"s3://crabby-images/1b90a/1b90addbf07d891365b7718a1901f01e7564243f" alt=""
Now create a file named .env
and add your connect URL. The contents of the file should look something like this (replacing <username> and <password> with the MongoDB username and password we created in the last section). Save the file once this is added.
MONGODB=mongodb+srv://<username>:<password>@cluster0.ltkorue.mongodb.net/?retryWrites=true&w=majority
Then we install the modules we need for the connection. Â From the terminal window that we used to run our node server (the one that we ran node server.js
). Â First stop the server (hit ctrl+c
). Â Now install the modules:
npm install mongoose dotenv
Now we can restart our server by running:
node server.js
If all runs properly, you should see the following on your console:
data:image/s3,"s3://crabby-images/931d7/931d7c97885381bcac3207c2a3a39cdaca083649" alt=""
Congrats as you are now connected to your database!
What's Next
Next, we need to start using your new database for various data! Â Want to see how we do that? Â Stay tuned or subscribe as we continue this app.