experimental.middlewareClientMaxBodySize
When middleware is used, Next.js automatically clones the request body and buffers it in memory to enable multiple reads - both in middleware and the underlying route handler. To prevent excessive memory usage, this configuration option sets a size limit on the buffered body.
By default, the maximum body size is 10MB. If a request body exceeds this limit, the body will only be buffered up to the limit, and a warning will be logged indicating which route exceeded the limit.
Options
String format (recommended)
Specify the size using a human-readable string format:
import type { NextConfig } from 'next' const nextConfig: NextConfig = { experimental: { middlewareClientMaxBodySize: '1mb', }, } export default nextConfig
Supported units: b
, kb
, mb
, gb
Number format
Alternatively, specify the size in bytes as a number:
import type { NextConfig } from 'next' const nextConfig: NextConfig = { experimental: { middlewareClientMaxBodySize: 1048576, // 1MB in bytes }, } export default nextConfig
Behavior
When a request body exceeds the configured limit:
- Next.js will buffer only the first N bytes (up to the limit)
- A warning will be logged to the console indicating the route that exceeded the limit
- The request will continue processing normally, but only the partial body will be available
- The request will not fail or return an error to the client
If your application needs to process the full request body, you should either:
- Increase the
middlewareClientMaxBodySize
limit - Handle the partial body gracefully in your application logic
Example
import { NextRequest, NextResponse } from 'next/server' export async function middleware(request: NextRequest) { // Next.js automatically buffers the body with the configured size limit // You can read the body in middleware... const body = await request.text() // If the body exceeded the limit, only partial data will be available console.log('Body size:', body.length) return NextResponse.next() }
import { NextRequest, NextResponse } from 'next/server' export async function POST(request: NextRequest) { // ...and the body is still available in your route handler const body = await request.text() console.log('Body in route handler:', body.length) return NextResponse.json({ received: body.length }) }
Good to know
- This setting only applies when middleware is used in your application
- The default limit of 10MB is designed to balance memory usage and typical use cases
- The limit applies per-request, not globally across all concurrent requests
- For applications handling large file uploads, consider increasing the limit accordingly
Was this helpful?