The Express app object list of must know features

The app object in express.js is what is returned when calling the express top level function by itself, rather than one of the additional methods attached to it like express.static. The app object contains many useful methods for working with http requests, setting up a rendering engine like ejs, an using additional middle like express-session, and passport. This post will serve as an overview of that app object, and everything that is of great importance when developing an node.js powered web applaction with express.js as part of the stack.

1 - Express app object and what to know before continuing to read.

This is an advanced post on the app object in express.js, it is not a getting started post on express.js, javaScript, node.js or any additional skills required before hand. When I was first writing this post I was using express 4.16.3, and yes the version number is something you want to keep a clone eye on with this project. For other topics on expressjs on this site I have a main post on expressjs that might be worth checking out.

2 - Express app object basic example

I often set up a new express project by calling npm init on a new project folder, and then install at a minimum express of course. In this example I will not be installing much of anything else, as this is just a basic example on the express app object.

1
2
3
4
$ mkdir express-demo
$ cd express-demo
$ npm init
$ npm install express --save

Then the next step would be to have an app.js file in the root of the demo. When writing this file one of the first things I would do is use require to get what is exported by express, which is the top level express function. Calling this function will give me a new app object that I can then use to do things like set up a handler for get requests, and start listening on a port for requests.

1
2
3
4
5
6
7
let express = require('express'),
app = express();
app.get('/', function(req,res){
res.send('hello world');
});
app.listen(8080);

The app.get, and app.listen are often the first methods one will become aware of when getting started with express. The app.get method is one of many methods that are used to respond to a certain find of http method know as a GET method. There are of course other methods for other kinds of requests, and even one that will work with all requests called app.all. The app.listen method is what can be used often in the main app.js file of a project to start the express app by having it listen on a given port for incoming traffic.

However this is much more to the object that an express developer should be aware of so lets get to it.

2 - app.use for using middleware

If you are not all ready aware of app.use this would be a good one to play with a little when it comes to making your own catalog of express demos for the sake of learning express. This method is what is used to use additional express middleware, including your own middleware that can do a whole range of things when working with incoming http requests.

For example if I want a middleware that just logs the incoming request headers to the console, and then continues on like normal I would just give app.use a single function literal log the headers in that function, and then call the next method that is provided as the third argument in that function.

1
2
3
4
5
6
7
app.use(function (req, res, next) {
console.log(req.headers);
next();
});

There is a great deal more to write about with app.use, but I have much to cover in this post.

3 - app.all app object method to respond to all http requests

There is also the app.all method app object method that works in a similar way to app.use.