MEAN Stack : Building REST API with Node and MongoDB
data:image/s3,"s3://crabby-images/5bda6/5bda6c624cb94a51d8af7fc85622d83f622d7368" alt="MEAN-Icon.png"
We'll setup a simple node server, and test REST APIs (GET, POST, DELETE). Then, we'll check the results via Browser and Postman Chrome extension.
The material is based on Build a RESTful API in 5 Minutes with NodeJS - Updated
This tutorial assumes we already have Node installed:
$ node -v v0.10.32 $ npm -v 2.14.1 $ mongo MongoDB shell version: 3.0.6 connecting to: test
Let's make our working directory, NodeREST:
$ mkdir NodeREST $ cd NodeREST
npm init will create a package.json:
$ npm init
Here is the package.json:
{ "name": "noderest", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1" }, "author": "", "license": "ISC" }
Let's install Express:
$ npm install express --save
Note that we used --save flag to put it into package.json file.
Let's make server.js:
var express = require('express'); var app = express(); app.get('/', function(req, res) { res.send('It works'); }); app.listen(3000); console.log('Listening on port 3000');
Run it:
T$ node server.js Listening on port 3000
data:image/s3,"s3://crabby-images/d2144/d2144da5a7e589fa5a0cf5f4b1bff56d2e843287" alt="localhost-3000-works.png"
We may want to install mongoose which a=is a wrapper for MongoDB and node-restful for our REST API:
$ npm install --save mongoose node-restful
Also, we need body-parser:
$ npm install --save body-parser
nodemon monitors for any changes in our node.js application and automatically restart the server. Let's install it:
$ sudo npm install -g nodemon
Now run nodemon instead of node:
$ nodemon server.js
Then, if we change a code, it will be reflected immediately because nodemon automatically restart the server:
... [nodemon] restarting due to changes... [nodemon] starting `node server.js` ...
Let's modify server.js to setup API:
// Dependencies var express = require('express'); var mongoose = require('mongoose'); var bodyParser = require('body-parser'); // MongoDB mongoose.connect('mongodb://localhost/rest_test'); // Express var app = express(); app.use(bodyParser.urlencoded({ extended: true })); app.use(bodyParser.json()); // Routes app.use('/api', require('./routes/api')); // Start server app.listen(3000); console.log('Listening on port 3000...');
Note that we add moongoose, body-parser, and routes.
Here is our /routes/api.js:
// Dependencies var express = require('express'); var router = express.Router(); // Routes router.get('/products', function(req, res) { res.send('api works!'); }); // Return router module.exports = router;
data:image/s3,"s3://crabby-images/a3a50/a3a501fb5f8a54a7e401b47348c8425e381e0e6f" alt="api-products-works.png"
Let's build our models to work with database.
// Dependencies var restful = require('node-restful'); var mongoose = restful.mongoose; // Schema var productSchema = new mongoose.Schema({ name: String, sku: String, price: Number }); // Return model module.exports = restful.model('Products', productSchema);
We need to change api.js accordingly:
// Dependencies var express = require('express'); var router = express.Router(); // Models var Product = require('../models/product'); // Routes Product.methods(['get', 'put', 'post', 'delete']); Product.register(router, '/products'); // Return router module.exports = router;
data:image/s3,"s3://crabby-images/ec4e1/ec4e126daf644b2f13a39e0ad607378af1db64f8" alt="Empty-Products.png"
Since we do not have any data, we got empty array of product.
On postman Chrome extensions, we get the same result:
data:image/s3,"s3://crabby-images/a24be/a24be4db956686f4ad573a0fce35563cdd1cb782" alt="postman-empty-array.png"
On postman Chrome extensions, we want to fill in data using POST:
{ "name" : "bogotobogo", "sku" : "qaz1234", "price" : 12.99 }
data:image/s3,"s3://crabby-images/05634/056349e89f56bf002e3bca05c2abcf4726c0df98" alt="postman-post-header.png"
data:image/s3,"s3://crabby-images/6b3c1/6b3c17d48fe230301870e1dc29bad4565c74f667" alt="postman-post-body.png"
Click "Send", and we can check if it's been really posted on Postman response pane:
data:image/s3,"s3://crabby-images/198d0/198d01dd6734c68edee78c6b1e92a20d11600d6c" alt="postman-body-check.png"
Or we can check via browser:
data:image/s3,"s3://crabby-images/61dfd/61dfdf137342646245b3288b2368298b1d350c15" alt="post-browser.png"
We can delete a record by appending id:
data:image/s3,"s3://crabby-images/7bc79/7bc79d934bea04affc263081a7357a0d5759a72a" alt="Delete-postman.png"
Click "Send", then we get empty list again:
data:image/s3,"s3://crabby-images/fe8f3/fe8f35e5d46c0ceab64fa9fb1b6451b8e6124032" alt="Empty-postman-after-delete.png"
Node.JS
Ph.D. / Golden Gate Ave, San Francisco / Seoul National Univ / Carnegie Mellon / UC Berkeley / DevOps / Deep Learning / Visualization