Accepting Data: Handling Form Data

Learn how to make your custom web server accept data from a form.

We'll cover the following

So far, your web server offers a read-only service: it publishes some data but doesn’t accept any… Until now!

Information submitted to a web server can be either form data or JSON data.

Handling form data

Form data comes encapsulated into the HTTP POST request sent by the client to the server. The first server task is to extract this information from the request. The simplest way to do this is to use a specialized npm package, such as multer. Install it with the npm install multer command or directly in your app dependencies.

  "dependencies": {
    ...
    "multer": "^1.3.0"
  },

Once multer is installed, add the following code towards the beginning of your server main file.

  // Load the multer package as a module
  const multer = require("multer");
  
  // Access the exported service
  const upload = multer();

The following route accepts form data sent to the "/animals" route. Notice the use of app.post() instead of app.get() to handle POST HTTP requests, and the addition of upload.array() as a second parameter to add a body object containing the fields of the form to the request object.

  // Handle form data submission to the "/animals" route
  app.post("/animals", upload.array(), (request, response) => {
const name = request.body.name;
const vote = request.body.strongest;
response.send(`Hello ${name}, you voted: ${vote}`);
  });

The values of the name and vote variables are extracted from the request body, and a string is constructed and sent back to the client.

Get hands-on with 1300+ tech skills courses.