Handling POST data
One of the most common REST methods used in network applications is POST. According to the REST specification, a POST is not idempotent, as opposed to most of the other well-known methods (GET, PUT, DELETE, and so on) that are. This is mentioned in order to point out that the handling of POST data will very often have a consequential effect on an application's state, and should therefore be handled with care.
We will now discuss the handling of the most common type of POST data, that which is submitted via forms. The more complex type of POST—multipart uploads—will be discussed in Chapter 4, Using Node to Access the Filesystem.
Let's create a server which will return a form to clients, and echo back any data that client submits with that form. We will need to first check the request URL, determining if this is a form request or a form submission, returning HTML for a form in the first case, and parsing submitted data in the second:
const http = require('http');
const qs = require('querystring');
http.createServer((request, response) => {
let body = "";
if(request.url === "/") {
response.writeHead(200, {
"Content-Type": "text/html"
});
return response.end(
'<form action="/submit" method="post">\
<input type="text" name="sometext">\
<input type="submit" value="Send some text">\
</form>'
);
}
}).listen(8080);
Note that the form we respond with has a single field named sometext. This form should POST data in the form sometext=entered_text to the path /submit. To catch this data, add the following conditional:
if(request.url === "/submit") {
request.on('readable', () => {
let data = request.read();
data && (body += data);
});
request.on('end', () => {
let fields = qs.parse(body);
response.end(`Thanks for sending: ${fields.sometext}`);
});
}
Once our POST stream ends we parse the body using Querystring.parse, giving us a key/value map from which we can pluck the value of the form element with name sometext, and respond to the client that we have received their data.