javascript2 Min Read

Request Entity Too Large(413) - Uploading File with Formdata with Axios and Custom header

Gorav Singal

January 15, 2022

TL;DR

The 413 Request Entity Too Large error when uploading files via Axios with form-data is caused by incorrect Content-Length; let Axios compute headers automatically instead of manually setting them.

Request Entity Too Large(413) - Uploading File with Formdata with Axios and Custom header

Introduction

I was trying to upload images to my backend using rest APIs. I was using form-data library with axios, so that I can pass authorization header as well.

I was getting error: Request Entity Too Large, with http Status of 413.

Earlier Code was:

const FormData = require("form-data");

const filepath = 'my-filepath';
let fileToUpload = new FormData();
fileToUpload.append("files", fs.createReadStream(filepath));

await axios.post(
    `${this._props.host}/upload`,
    fileToUpload,
    {
        headers: {
            Authorization: `Bearer ${this._jwt}`
        },
    }
);

Error:

Request failed with status code 413

Solution

You need to pass a header Content-Type with value of multipart/form-data; and a unique boundary. When using form-data library. It also gives you a method: getHeaders().

The code becomes:

const FormData = require("form-data");

const filepath = 'my-filepath';
let fileToUpload = new FormData();
fileToUpload.append("files", fs.createReadStream(filepath));

await axios.post(
    `${this._props.host}/upload`,
    fileToUpload,
    {
        headers: {
            ...fileToUpload.getHeaders(),
            Authorization: `Bearer ${this._jwt}`
        },
    }
);

If you print fileToUpload.getHeaders(), you will get

'content-type': 'multipart/form-data; boundary=--------------------------151840689896304164188529'

And, it works.

What is Unique Boundary

In simple terms, you know that the server knows that multiple parameters are separated by an ampersand (&) character. And, if user need to pass the ampersand (&) character in the request parameters, then it have to be encoded.

But, how the server will know when to read the file data and when to stop (start and end) in the case of multipart/form-data.

It has to be similar to ampersand philosophy or contract.

This unique boundary is used for that purpose. It is to tell the server how to split the data it receives in multipart/form-data. So, what is unique about it. This value has to be unique in the request. i.e. It should not come within the content of the request or the payload.

Share

Related Posts

Authenticating Strapi backend with Next.js and next-auth using credentials and jwt

Authenticating Strapi backend with Next.js and next-auth using credentials and jwt

Introduction Strapi is a backend system provides basic crud operations with…

Nextjs - Fixing Loading External Images and Issue of Url Paramater Not Allowed

Nextjs - Fixing Loading External Images and Issue of Url Paramater Not Allowed

Introduction In this post, we will see How to load external images to your next…

Nextjs - How to Build Next.js Application on Docker and Pass API Url

Nextjs - How to Build Next.js Application on Docker and Pass API Url

Introduction In this post we will see: How to prepare a docker image for your…

Nextjs - How to Redirect to Another Page and Pass State

Nextjs - How to Redirect to Another Page and Pass State

Introduction We have a page, for example a . And, upon submission we would want…

How to use Draft.js WYSWYG with Next.js and Strapi Backend, Edit/Update Saved Article

How to use Draft.js WYSWYG with Next.js and Strapi Backend, Edit/Update Saved Article

Introduction This post is in contuation of our previous post: How to use Draft…

How to use Draft.js WYSWYG with Next.js and Strapi Backend, Create and View Article with Image Upload

How to use Draft.js WYSWYG with Next.js and Strapi Backend, Create and View Article with Image Upload

Introduction In this post, we will use in Next.js with strapi. And, we will…

Latest Posts

AI Video Generation in 2025 — Models, Costs, and How to Build a Cost-Effective Pipeline

AI Video Generation in 2025 — Models, Costs, and How to Build a Cost-Effective Pipeline

AI video generation went from “cool demo” to “usable in production” in 2024-202…

AI Models in 2025 — Cost, Capabilities, and Which One to Use

AI Models in 2025 — Cost, Capabilities, and Which One to Use

Choosing the right AI model is one of the most impactful decisions you’ll make…

AI Image Generation in 2025 — Models, Costs, and How to Optimize Spend

AI Image Generation in 2025 — Models, Costs, and How to Optimize Spend

Generating one image with AI costs between $0.002 and $0.12. That might sound…

AI Coding Assistants in 2025 — Every Tool Compared, and Which One to Actually Use

AI Coding Assistants in 2025 — Every Tool Compared, and Which One to Actually Use

Two years ago, AI coding meant one thing: GitHub Copilot autocompleting your…

AI Agents Demystified — It's Just Automation With a Better Brain

AI Agents Demystified — It's Just Automation With a Better Brain

Let’s cut through the noise. If you read Twitter or LinkedIn, you’d think “AI…

Supply Chain Security — Protecting Your Software Pipeline

Supply Chain Security — Protecting Your Software Pipeline

In 2024, a single malicious contributor nearly compromised every Linux system on…