Creating a Node
Application with MongoDB Connectivity
mkdir
node-demo
cd node-demo
Once we are in the
directory we will need to create an application and we can do this by running
the command
npm init
Installing
Express
npm install express --save
Create app.js file
var express
= require("express");
var app = express();
var port = 3000;
app.get("/", (req, res)
=> {
res.send("Hello World");
});
app.listen(port, () => {
console.log("Server listening on port
" + port);
});
To test our application
you can go to the terminal and enter the command
node app.js
Open up a browser and
navigate to the url
http://localhost:3000
Creating
Website to Save Data to MongoDB Database
Create index.html
<!DOCTYPE html>
<html>
<head>
<title>Intro to Node and MongoDB</title>
</head>
<body>
<h1>Into to Node and MongoDB</h1>
<form method="post" action="/addname">
<label>Enter Your Name</label><br>
<input type="text" name="firstName" placeholder="Enter first name..." required>
<input type="text" name="lastName" placeholder="Enter last name..." required>
<input type="submit" value="Add Name">
</form>
</body>
</html>
The app.get
lines
will need to be changed
app.get("/", (req, res) => {
res.sendFile(__dirname +
"/index.html");
});
Once
you have saved your app.js file, we can test it by going to terminal and
running node
app.js
Open your browser
and navigate to “http://localhost:3000”. You will see the following
Connecting
to the Database
To connect to the
MongoDB database we are going to use a module called Mongoose. We will need to
install mongoose module just like we did with express. Go to your terminal and
enter the following command.
npm install mongoose –save
Connecting
to the Database
Now that we have
the mongoose module installed, we need to connect to the database in our app.js
file. MongoDB, by default, runs on port 27017. You connect to the database by
telling it the location of the database and the name of the database.
In our app.js file
after the line for the port and before the app.get line, enter the following
two lines to get access to mongoose and to connect to the database. For the
database, I am going to use “node-demo”.
var mongoose = require("mongoose");
mongoose.Promise = global.Promise;
mongoose.connect("mongodb://localhost:27017/node-demo");
var User = mongoose.model("User", nameSchema);
app.get("/", (req, res) => {
res.sendFile(__dirname + "/index.html");
});
Creating a Database Schema
var nameSchema = new mongoose.Schema({
firstName:
String,
lastName:
String
});
var User = mongoose.model("User", nameSchema);
Creating a
RESTful API
We will need to
create an endpoint that will be used to send data to our server. Once the
server receives this data then it will store the data in the database.
An endpoint is a
route that our server will be listening to to get data from the browser. We
already have one route that we have created already in the application and that
is the route that is listening at the endpoint “/” which is the homepage of our
application.
HTML Verbs
in a REST API
The
communication between the client(the browser) and the server is done through an
HTTP verb. The most common HTTP verbs are
GET, PUT, POST, and DELETE
.
HTTP
Verb Operation
|
|
GET
Read
|
|
POST
Create
|
|
PUT
Update
|
|
DELETE
Delete
|
Building a
CRUD endpoint
If you remember,
the form in our index.html file used a post method to call this endpoint. We
will now create this endpoint.
In our previous
endpoint we used a “GET” http verb to display the index.html file. We are going
to do something very similar but instead of using “GET”, we are going to use
“POST”. To get started this is what the framework of our endpoint will look
like.
app.post("/addname", (req, res) => {
});
Express
Middleware
To fill out the
contents of our endpoint, we want to store the firstName and lastName entered
by the user into the database. The values for firstName and lastName are in the
body of the request that we send to the server. We want to capture that data,
convert it to JSON and store it into the database.
Express.js version
4 removed all middleware. To parse the data in the body we will need to add
middleware into our application to provide this functionality. We will be using
the body-parser module. We need to install it, so in your terminal window enter
the following command.
npm install body-parser --save
To
add the body-parser middleware to our application and configure it, we can add
the following lines directly after the line that sets our port.
var bodyParser = require('body-parser');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
Saving
data to database
Mongoose provides a
save function that will take a JSON object and store it in the database. Our
body-parser middleware, will convert the user’s input into the JSON format for
us.
To save the data
into the database, we need to create a new instance of our model that we
created early. We will pass into this instance the user’s input. Once we have it
then we just need to enter the command “save”.
app.post("/addname", (req, res) => {
var myData = new User(req.body);
myData.save()
.then(item => {
res.send("item saved to database");
})
.catch(err => {
res.status(400).send("unable to save to database");
});
});
Testing
our code
Save your code. Go to your terminal and enter the
command node app.js
to
start our server. Open up your browser and navigate to the URL
“http://localhost:3000”. You will see our index.html file displayed to you.