Handling File Uploads in Node.js with Multer: A Comprehensive Guide

Nitin Rachabathuni
3 min readMar 10, 2024

--

File uploads are a fundamental aspect of many web applications, from social networks to cloud storage services. In Node.js, handling file uploads can be seamlessly managed with Multer, a middleware for Express applications. This article provides a step-by-step guide to implementing file uploads in your Node.js applications using Multer.

Introduction to Multer

Multer is a Node.js middleware which simplifies handling multipart/form-data, primarily used for uploading files. It integrates easily with Express, a popular web framework for Node.js, making file uploads straightforward and efficient.

Setting Up Your Project

Before diving into Multer, ensure you have Node.js installed on your machine. Start by creating a new directory for your project and initialize it with npm init to create a package.json file. Install Express and Multer:

npm install express multer --save

Basic File Upload Example

Let’s start with a simple file upload example. Create an app.js file and set up your Express application:

const express = require('express');
const multer = require('multer');
const app = express();
const port = 3000;

// Configure storage
const storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, 'uploads/');
},
filename: function (req, file, cb) {
cb(null, file.fieldname + '-' + Date.now());
}
});

const upload = multer({ storage: storage });

// Routes
app.post('/upload', upload.single('myFile'), (req, res, next) => {
const file = req.file;
if (!file) {
return res.status(400).send('Please upload a file');
}
res.send('File uploaded successfully');
});

app.listen(port, () => console.log(`App listening on port ${port}!`));

In this example, we’ve set up an Express server that listens on port 3000. We configure Multer to store uploaded files in the uploads/ directory with a unique filename. The /upload route handles file uploads using Multer's single method, indicating that we expect a single file upload with the field name myFile.

Handling Multiple File Uploads

Multer also supports multiple file uploads. Adjust the route to handle multiple files:

app.post('/uploadMultiple', upload.array('myFiles', 3), (req, res, next) => {
const files = req.files;
if (!files || files.length === 0) {
return res.status(400).send('Please upload files');
}
res.send(`${files.length} files uploaded successfully`);
});

In this route, upload.array('myFiles', 3) indicates that we expect multiple files (up to 3) with the field name myFiles.

Filtering Files and Setting File Size Limits

Multer provides options to filter files and set size limits for uploads, enhancing control and security:

const uploadWithFilter = multer({
storage: storage,
fileFilter: function (req, file, cb) {
if (file.mimetype === 'image/jpeg' || file.mimetype === 'image/png') {
cb(null, true);
} else {
cb(null, false);
}
},
limits: {
fileSize: 1024 * 1024 * 2 // 2 MB
}
});

In this configuration, only JPEG and PNG files under 2 MB are accepted.

Conclusion

Multer makes handling file uploads in Node.js applications straightforward and efficient. By configuring storage options, handling single or multiple file uploads, and setting constraints like file types and sizes, developers can implement robust file upload functionality in their web applications.

Remember to validate and sanitize file inputs to protect your application from malicious files and to comply with data handling policies.

Thank you for reading my article! For more updates and useful information, feel free to connect with me on LinkedIn and follow me on Twitter. I look forward to engaging with more like-minded professionals and sharing valuable insights.

--

--

Nitin Rachabathuni
Nitin Rachabathuni

Written by Nitin Rachabathuni

Seeking freelance opportunities | React.js, Next.js, Vue.js, Angular, Node.js, Commercetools, Merchant Center, Frontastic, Azure, AWS | +91-9642222836

No responses yet