Node has a built-in HTTP module for making and responding to requests. In this training, we'll examine the Node HTTP docs and annotate server code. We'll become familiar with the HTTP module, as well as using function signatures to find the correct documentation for a procedure. We'll also look at a promisified version of a simple server.
By the end of this, developers should be able to:
- Diagram the flow of a server written in Node.
- Annotate code using documentation.
- Find documentation based on function signature.
- Fork and clone this repository.
- Install dependencies with
npm install
.
Read the following documentation from the Node HTTP module. While reading, take note of any new concepts or vocabulary that is confusing. Pay attention to function signatures. When you're finished taking notes, research one or two points you'd like made clearer. We will discuss our findings.
- Class:
http.Server
- Class:
http.ServerResponse
http.Server
Event:'request'
server.listen(path[, callback])
server.listen(port[, hostname][, backlog][, callback])
An echo server is a server that responds with all the information it received during a request. It's a bit like "Hello, World!".
Let's run the echo server with node lib/htpp-server.js
.
You should see echo server listening
. Now make a request with curl
:
curl --include --request GET \
http://localhost:3000/people/?name=Jason&role=Awesome
Next, try this request:
curl --include --request POST http://localhost:3000/sign-in \
--header "Content-Type: application/json" \
--data "{
\"credentials\": {
\"email\": \"[email protected]\",
\"password\": \"an example password\"
}
}"
Let's read the code in lib/http-server.js
.
Our goal is to annotate the code as we try to understand what it is doing at a
high level.
As we take notes, write questions you have along with your notes.
After we annotate a few lines together, you may continue annotating on your own.
Read the code in lib/http-server-promises.js
.
Compare it to the code in lib/http-server.js
.
Annotate any questions you have about promises.
- All content is licensed under a CCBYNCSA 4.0 license.
- All software code is licensed under GNU GPLv3. For commercial use or alternative licensing, please contact [email protected].