Express.
js
Express.js provides an easy way to create web server and render HTML pages for different
HTTP requests by configuring routes for your application.
"Express is a fast, unopinionated minimalist web framework for Node.js" - official web
site: Expressjs.com
Express.js is a web application framework for Node.js. It provides various features that make
web application development fast and easy which otherwise takes more time using only
Node.js.
Express.js is based on the Node.js middleware module called connect which in turn
uses http module. So, any middleware which is based on connect will also work with
Express.js.
Advantages of Express.js
   1. Makes Node.js web application development fast and easy.
   2. Easy to configure and customize.
   3. Allows you to define routes of your application based on HTTP methods and URLs.
   4. Includes various middleware modules which you can use to perform additional tasks
      on request and response.
   5. Easy to integrate with different template engines like Jade, Vash, EJS etc.
   6. Allows you to define an error handling middleware.
   7. Easy to serve static files and resources of your application.
   8. Allows you to create REST API server.
Prepared by, Shobha Rani, Dr. AIT                                                     Page 1
   9. Easy to connect with databases such as MongoDB, Redis, MySQL
Difference between Node.js and Express.js
Node.js is a platform for building the i/o applications which are server-side event-driven and
made using JavaScript.
Express.js is a framework based on Node.js for which it is used for building web-application
using approaches and principles of Node.js event-driven.
 Feature                   Express.js                       Node.js
                           It is used to build web-apps
                           using      approaches    and      It is used to build server-side,
 Usage                     principles of Node.js.           input-output, event-driven apps.
 Level of features         More features than Node.js.      Fewer features.
                                                            It is built on Google’s V8
 Building Block            It is built on Node.js.          engine.
 Written in                JavaScript                       C, C++, JavaScript
                                                            Run-time          platform       or
                                                            environment        designed     for
                                                            server-side       execution      of
 Framework/Platform        Framework based on Node.js.      JavaScript.
 Controllers               Controllers are provided.        Controllers are not provided.
 Routing                   Routing is provided.             Routing is not provided.
                           Uses middleware for the
                           arrangement of functions
 Middleware                systematically server-side.      Doesn’t use such a provision.
 Coding time               It requires less coding time.    It requires more coding time.
ExpressJS is one of the most popular HTTP server libraries for Node. js, which by default isn't
as friendly for API development. Using Express, API development is simple which makes
development faster, more readable and simpler.
Prepared by, Shobha Rani, Dr. AIT                                                         Page 2
Install Express.js
Install express.js using npm. The following command will install latest version of express.js
globally on your machine so that every Node.js application on your machine can use it.
npm install express
Express apps utilize routers that are essentially containers for a set of middleware. We can put
this middleware holder only on a specific route, which allows us to keep our logic in separate
files and bring them together on our terms.
First Applications: app.js
var express = require('express');
var app = express();
app.get('/', function(req, res){
  res.send("Welcome to Full Stack Course!");
});
app.listen(8080);
In the terminal, run the sample application
>node app.js
This will start the server. To test this app, open your browser and go to http://localhost:3000
Working of App.js
The first line imports Express in our file, we have access to it through the variable Express. We
use it to create an application and assign it to var app.
app.get(route, callback)
This function tells what to do when a get request at the given route is called. The callback
function has 2 parameters, request(req) and response(res). The request object(req) represents
the HTTP request and has properties for the request query string, parameters, body, HTTP
headers, etc. Similarly, the response object represents the HTTP response that the Express app
sends when it receives an HTTP request.
Prepared by, Shobha Rani, Dr. AIT                                                         Page 3
res.send()
This function takes an object as input and it sends this to the requesting client. Here we are
sending the string " Welcome to Full Stack Course!".
app.listen(port, [host], [backlog], [callback]])
This function binds and listens for connections on the specified host and port. Port is the only
required parameter here.
 S.No. Argument & Description
 1        port
          A port number on which the server should accept incoming requests.
 2        host
          Name of the domain. This is set when apps are deployed to the cloud.
 3        backlog
          The maximum number of queued pending connections. The default is 511.
 4        callback
          An asynchronous function that is called when the server starts listening for requests.
Routing is the process through which the user is navigated to different pages on a website.
Rendering is the process of putting those pages on the UI. Every time you request a route to a
particular page, you are also rendering that page, but not every render is an outcome of a route.
Web frameworks provide resources such as HTML pages, scripts, images, etc. at different
routes. The following function is used to define routes in an Express application −
app.method(path, handler)
This METHOD can be applied to any one of the HTTP verbs – get, set, put, delete. An
alternate method also exists, which executes independent of the request type. Path is the route
at which the request will run. Handler is a callback function that executes when a matching
request type is found on the relevant route.
Prepared by, Shobha Rani, Dr. AIT                                                          Page 4
Example to implement app.method
var express = require('express');
var app = express();
app.get('/welcome', function(req, res){
  res.send("Welcome to Full Stack Course!");
});
app.listen(8080);
If we run our application and go to localhost:8080/welcome, the server receives a get request
at route "/welcome",
Express app executes the callback function attached to this route and sends “Welcome to Full
Stack Course!” as the response.
                    HTTP                                         Express
 HTTP comes inbuilt along with NodeJS
 that is, we don’t need to install it           Express is installed explicitly using npm
 explicitly.                                    command: npm install express
 HTTP is not a framework as a whole,
 rather it is just a module.                    Express is a framework as a whole.
                                                Express provide express.static function for
 HTTP does not provide any support for          static           asset              hosting.
 static asset hosting.                          Example: app.use(express.static(‘public’));
 HTTP is an independent module.                 Express is made on top of the HTTP module.
 HTTP module provides various tools             Express along with what HTTP does provide
 (functions) to do things for networking like   many more functions in order to make
 making a server, client, etc.                  development easy.
Prepared by, Shobha Rani, Dr. AIT                                                      Page 5
API in Use
NODE-Express involving Middleware
Express is a routing and middleware web framework that has minimal functionality of its own:
An Express application is essentially a series of middleware function calls.
Middleware functions are functions that have access to the request object (req), the response
object (res), and the next middleware function in the application’s request-response cycle. The
next middleware function is commonly denoted by a variable named next.
Middleware Functions
Middleware functions are those functions that have access to the request object (req), the
response object (res), and the next function in the application’s request-response cycle. The
objective of these functions is to modify request and response objects for tasks like parsing
request bodies, adding response headers, make other changes to request-response cycle, end
the request-response cycle and call the next middleware function.
Prepared by, Shobha Rani, Dr. AIT                                                       Page 6
The next function is a function in the Express router which is used to execute the other
middleware functions succeeding the current middleware. If a middleware function does
include next() that means the request-response cycle is ended there.
Middleware functions can perform the following tasks:
   •   Execute any code.
   •   Make changes to the request and the response objects.
   •   End the request-response cycle.
   •   Call the next middleware function in the stack.
If the current middleware function does not end the request-response cycle, it must
call next() to pass control to the next middleware function. Otherwise, the request will be left
hanging.
The following figure shows the elements of a middleware function call:
                                                                  HTTP method for which the middleware
                                                                  function applies.
                                                                  Path (route) for which the middleware
                                                                  function applies.
                                                                  The middleware function.
                                                                  Callback argument to the middleware
                                                                  function, called "next" by convention.
                                                                  HTTP response argument to the middleware
                                                                  function, called "res" by convention.
                                                                  HTTP request argument to the middleware
                                                                  function, called "req" by convention.
Prepared by, Shobha Rani, Dr. AIT                                                            Page 7
Advantages of using middleware:
   •   Middleware can process request objects multiple times before the server works for that
       request.
   •   Middleware can be used to add logging and authentication functionality.
   •   Middleware improves client-side rendering performance.
   •   Middleware is used for setting some specific HTTP headers.
   •   Middleware helps for Optimization and better performance.
An Express application can use the following types of middleware:
   •   Application-level middleware
   •   Router-level middleware
   •   Error-handling middleware
   •   Built-in middleware
   •   Third-party middleware
Examples:
Simple program to use middle ware in action
var express = require('express');
var app = express();
//Simple request
app.use(function(req, res, next){
   console.log("WELOCME TO Dr. AIT!!");
   //This function call is very important. It tells that more processing is
   //required for the current request and is in the next middleware
   //function route handler.
   next();
});
// Route handler that sends the response
app.get('/', function(req, res){
    res.send('Introduction to EXpress Js');
 });
Prepared by, Shobha Rani, Dr. AIT                                                     Page 8
app.listen(8080);
Order of Middleware Calls
One of the most important things about middleware in Express is the order in which they are
written/included in your file; the order in which they are executed, given that the route matches
also needs to be considered.
For example, in the following code snippet, the first function executes first, then the route
handler and then the end function. This example summarizes how to use middleware before
and after route handler; also how a route handler can be used as a middleware itself.
Example:
var express = require('express');
var app = express();
//First middleware before response is sent
app.use(function(req, res, next){
   console.log("Start");
   next();
});
//Milldle ware handler
app.get('/', function(req, res, next){
   res.send("Middle");
   next();
});
app.use('/', function(req, res){
   console.log('End');
});
app.listen(8080);
When we visit '/' after running this code, we receive the response as Middle and on our console
−
Start
End
The following diagram summarizes about middleware −
Prepared by, Shobha Rani, Dr. AIT                                                         Page 9
Routing is made from the word route. It is used to determine the specific behavior of an
application. It specifies how an application responds to a client request to a particular route,
URI or path and a specific HTTP request method (GET, POST, etc.). It can handle different
types of HTTP requests.
Route Parameter
Routing refers to determining how an application responds to a client request to a particular
endpoint, which is a URI (or path) and a specific HTTP request method (GET, POST, and so
on). Each route can have one or more handler functions, which are executed when the route is
matched.
Route definition takes the following structure:
app.METHOD(PATH, HANDLER)
Route methods
A route method is derived from one of the HTTP methods, and is attached to an instance of
the express class. The primary or most commonly-used HTTP methods are POST, GET, PUT,
PATCH, and DELETE. These methods correspond to create, read, update, and delete (or
CRUD) operations, respectively.
There are four main HTTP methods that can be supplied within the request. These methods
help in specifying the operation requested by the user. Below table lists down all methods along
with their explanations:
Prepared by, Shobha Rani, Dr. AIT                                                       Page 10
Method                Description
                      The HTTP GET method helps in requesting for the representation of a
1. GET                specific resource by the client. The requests having GET just retrieves
                      data and without causing any effect.
                      The HTTP POST method helps in requesting the server to accept the data
2. POST               that is enclosed within the request as a new object of the resource as
                      identified by the URI.
                      The HTTP PUT method helps in requesting the server to accept the data
3. PUT                that is enclosed within the request as an alteration to the existing object
                      which is identified by the provided URI.
                      The HTTP DELETE method helps in requesting the server to delete a
4. DELETE
                      specific resource from the destination.
Example: Implementation of middle ware function as router
//const { query } = require('express');
var express = require('express');
var app = express();
const router=express.Router()
// Use of router as Middle Ware Function
const urlCheck = function (req, res, next) {
    console.log("Requested Url is :",req.originalUrl)
    next()
    }
//app.use(urlCheck);
//First middleware before response is sent
app.get('/', function (req, res) {
    res.send("Welcome to Dr. AIT Home Page")
});
//app.get('/user', function (req, res) {
//Use of Router as middle ware on User page
router.get('/user',urlCheck, function (req, res) {
    res.send("Welcome to Student Page")
Prepared by, Shobha Rani, Dr. AIT                                                        Page 11
});
// Middle ware on Contact page
app.get('/contact', function (req, res) {
    res.send("Welcome to Contact Page")
});
app.use('/',router)
app.listen(8080);
Program to implement middleware function with query
//const { query } = require('express');
var express = require('express');
var app = express();
// Use of Middle Ware Function
const reqFilter = (req, res, next) => {
      if (!req.query.age) {
          res.send(`<h2>Provide Correct Age</h2>`)
      }
      else if(req.query.age<18){
          res.send("YOu are under aged")
      }
      else{
          next()
      }
}
app.use(reqFilter);
//First middleware before response is sent
app.get('/', function (req, res) {
    res.send("Welcome to Home Page")
});
app.get('/user', function (req, res) {
    res.send("You are eligible")
});
app.listen(8080);
console.log("Listening to port 8080")
Prepared by, Shobha Rani, Dr. AIT                     Page 12
Program to implement router as middle ware function and send .html file as response
//const { query } = require('express');
var express = require('express');
var app = express();
const router=express.Router()
// Use of router as Middle Ware Function
const urlCheck = function (req, res, next) {
    console.log("Requested Url is :",req.originalUrl)
    next()
    }
//app.use(urlCheck);
//First middleware before response is sent
app.get('/', function (req, res) {
    res.send("Welcome to Dr. AIT Home Page")
});
//app.get('/user', function (req, res) {
//Use of Router as middle ware on User page
router.get('/login',urlCheck, function (req, res) {
    //res.send("Welcome to Student Page")
    res.sendFile(__dirname+"/login.html")
});
// Middle ware on Contact page
app.get('/contact', function (req, res) {
    //res.send("Welcome to Contact Page")
    res.sendFile(__dirname+"/contact.html")
});
app.use('/',router)
app.listen(8080);
Prepared by, Shobha Rani, Dr. AIT                                              Page 13