⚠️ This lesson is retired and might contain outdated information.

Setup a Web Server in Node.js using Express

Joel Lord
InstructorJoel Lord
Share this video with your friends

Social Share Links

Send Tweet
Published 7 years ago
Updated 2 years ago

In this lesson, we build a very simple Express server. This server will have a single route that displays the current date and time and a handler for 404 pages.

Instructor: [00:00] To build your first Express server, the first thing you need to do is to require Express. In order for your code to be able to use it, you need to install it using npm. We can open a terminal to npm install Express, and all the files should be included now.

[00:16] We'll go back to our code. We'll declare a new constant app which will use the Express library that we've just included. We'll also declare a new constant for the port number. We'll use 8888 for now.

[00:30] Then we can do our first route. We'll use app.get, and we'll specify the name of the route. In this case, we're using status, and it takes a callback which has a request and a response as parameters.

[00:44] For this route, we will return to local time. We'll start by declaring the local time in a constant. We'll just use a new date, and we'll use the to local time string.

[00:57] Now we can start building our response. We'll give it a status of 200, which is a success code. We'll send simply a string which says, "Server time is," and we'll use the local time which we've just defined.

[01:13] Let's also add a catchall route. We'll just use star, which means any route that wasn't defined already.

[01:19] It also takes a callback with a request and response. We can build our response here, and it will simply sense that as 404, or page not found.

[01:30] Finally, we'll use app.listen to initialize our server. It'll take a port -- which we've defined earlier -- as a parameter, and a callback for on success.

[01:42] We'll simply say server is running on port, and we'll specify the port number here. You now have your first express server.

[01:53] If we go back to our terminal, we can start the server by using Node. We've got our server running.

[02:02] Now if we go through our browser window, we can type in the localhost, 8888. We'll get a page not found because that route was not defined.

[02:10] We can use /status to get the server time, and any other page will give us a 404 error. That's it. You've got your first Express server up and running.

ajando
ajando
~ 7 years ago

Hello Joel, is there a specific reason you used (new Date()).toLocaleTimeString() and not new Date().toLocaleTimeString()

Joel Lord
Joel Lordinstructor
~ 7 years ago

There were no specific reason, mostly readability.

rankpy
rankpy
~ 7 years ago

I am receiving this message Server time is ${localTime}. time is not rendering.


const express = require("express");

const app =express(); const PORT = 8888;

app.get("/status", (requestAnimationFrame, res) => { const localTime = (new Date()).toLocaleTimeString(); res .status(200) .send('Server time is ${localTime}.');

});

app.get("*", (Reflect, res) => { res.sendStatus(404); });

app.listen(PORT, () => { console.log('Server is running on port ${PORT}.'); });

rankpy
rankpy
~ 7 years ago

i see I dont know how animation got in there

Joel Lord
Joel Lordinstructor
~ 7 years ago

I am receiving this message Server time is ${localTime}. time is not rendering.

You are using ' for the string. Try using backticks (`). For more info on this topic, take a look at https://egghead.io/lessons/javascript-use-template-literals-in-es6

Markdown supported.
Become a member to join the discussionEnroll Today