Open In App

How to Handle file upload in Node with Multer and Postman

In this article, we will discuss about file upload functionality using Node, Multer and Postman. File Uploading is a significant functionality of any web service to get the data from the users in the form of files.

To implement this feature we will use Node JS with Express and Multer library. Finally, we will use the Postman API platform to test the REST endpoint for file uploading.



Prerequisites

The following tools should be installed in your system to follow along with this article, incase you don’t have it already installed use the given links (node, postman) to download and install it in your system. Make sure you are using the same version of the tools mentioned.

Approach to handle file upload in Node

Let’s discuss our approach for implementing the file upload functionality in Node.js.

Project Structure:

project structure

Handling File Upload in Node JS

Follow the step by step procedure to handle file upload in node, create a folder to store the project files and open that folder in VS Code or any of your preferred Text Editor. The entire workflow has been divided into three major process,

Steps to create Basic Express Application

Step 1: Create a basic node application with the below npm command.

npm init -y

`-y` flag is used to say yes to all of the details asked by npm, if you need to change any option, answer it manually by omitting the flag in the command.

init node app

Step 2:

npm install --save express multer

installing dependencies

Step 3: Create a file named server.js under the same directory to host the express server. Add the below code to bootstrap the server for giving a hello message on hitting the “/” endpoint




const express = require("express");
const app = express();
 
// port for our project to run
const PORT = 8080;
 
// A simple greeting message to
// test the app
app.get("/", (req, res) => {
  res.send("Hello from Express!");
});
 
// Start the server using listen method of express
// pass the port and callback function on successful start
app.listen(8080, () => {
  console.log(`server is started and
               listening at port: ${PORT}`);
});

A simple get method is added to the “/” path to check whether the app is starting fine and responding back to the request.

Step 4: Start the server and test the initial greeting message in Postman, to start the server use the below command.

npm start

Step 5:

initial hello ouput

Adding File Upload functionality with Multer

Step 6: Create a file named file-upload.js in the current directory to store the file upload handling functions and Multer configuration.




const multer = require("multer");
const path = require("node:path");
 
const storageConfig = multer.diskStorage({
      // destinations is uploads folder
      // under the project directory
    destination: path.join(__dirname, "uploads"),
    filename: (req, file, res) => {
          // file name is prepended with current time
          // in milliseconds to handle duplicate file names
        res(null, Date.now() + "-" + file.originalname);
    },
});
 
// file filter for filtering only images
const fileFilterConfig = function(req, file, cb) {
    if (file.mimetype === "image/jpeg"
        || file.mimetype === "image/png") {
          // calling callback with true
          // as mimetype of file is image
        cb(null, true);
    } else {
          // false to indicate not to store the file
        cb(null, false);
    }
};
 
// creating multer object for storing
// with configuration
const upload = multer({
      // applying storage and file filter
    storage: storageConfig,
    limits: {
          // limits file size to 5 MB
        fileSize: 1024 * 1024 * 5
    },
    fileFilter: fileFilterConfig,
});
 
module.exports = upload;

Explanation of the above code:

Step 7: Import the upload function in the server.js to use in the “/upload” REST endpoint.




const express = require("express");
const app = express();
 
// port for our project to run
const PORT = 8080;
 
// A simple greeting message to
// test the app
app.get("/", (req, res) => {
    res.send("Hello from Express!");
});
 
// add code for upload functinality using POST method
app.post("/upload", upload.single("file"), (req, res) => {
      // check whether req.file contians the file
      // if not multer is failed to parse so notify the client
    if (!req.file) {
        res.status(413).send(`File not uploaded!, Please
                              attach jpeg file under 5 MB`);
        return;
    }
      // successfull completion
    res.status(201).send("Files uploaded successfully");
});
 
// Start the server using listen method of express
// pass the port and callback function on successful start
app.listen(8080, () => {
  console.log(`server is started and
                                  listening at port: ${PORT}`);
});

Explanation of the above code:

Testing File Upload with Postman

Step 8:

Output:

final output


Article Tags :