Bird
Raised Fist0
NextJSframework~5 mins

Request parsing in route handlers in NextJS

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Introduction

Request parsing helps your app understand what the user sends. It turns raw data into usable information.

When you want to get data from a form submission.
When your app needs to read JSON sent by the user.
When you want to handle query parameters from a URL.
When you need to read headers or cookies from a request.
When building APIs that accept user input.
Syntax
NextJS
export async function POST(request) {
  const data = await request.json();
  // use data here
  return new Response('Received');
}
Use request.json() to parse JSON body data.
You can also use request.text() or request.formData() depending on the data type.
Examples
Parse JSON body and greet by name.
NextJS
export async function POST(request) {
  const jsonData = await request.json();
  return new Response(`Hello, ${jsonData.name}`);
}
Read query parameter id from the URL.
NextJS
export async function GET(request) {
  const url = new URL(request.url);
  const id = url.searchParams.get('id');
  return new Response(`ID is ${id}`);
}
Parse form data sent from a form submission.
NextJS
export async function POST(request) {
  const formData = await request.formData();
  const email = formData.get('email');
  return new Response(`Email received: ${email}`);
}
Sample Program

This route handler reads JSON data sent in a POST request. It extracts name and age from the data and sends back a friendly message.

NextJS
export async function POST(request) {
  // Parse JSON data from request body
  const data = await request.json();
  // Extract name and age
  const { name, age } = data;
  // Create a response message
  const message = `Hello, ${name}! You are ${age} years old.`;
  return new Response(message);
}
OutputSuccess
Important Notes

Always check the content type before parsing to avoid errors.

Use await because parsing is asynchronous.

For GET requests, parse URL parameters instead of body data.

Summary

Request parsing turns raw user data into usable info.

Use request.json(), request.formData(), or URL parsing depending on data type.

Parsing is key to handling user input in Next.js route handlers.

Practice

(1/5)
1. In Next.js route handlers, which method is used to parse JSON data from a POST request's body?
easy
A. request.json()
B. request.text()
C. request.formData()
D. request.body()

Solution

  1. Step 1: Understand the data type sent in the request

    JSON data requires parsing as JSON, not as text or form data.
  2. Step 2: Identify the correct parsing method in Next.js route handlers

    The request.json() method parses the request body as JSON.
  3. Final Answer:

    request.json() -> Option A
  4. Quick Check:

    JSON data parsing = request.json() [OK]
Hint: Use request.json() to parse JSON bodies in Next.js [OK]
Common Mistakes:
  • Using request.text() for JSON data
  • Trying to use request.body() which is not a method
  • Using request.formData() for JSON instead of form data
2. Which of the following is the correct syntax to parse form data in a Next.js route handler?
easy
A. const data = await request.json();
B. const data = await request.formData();
C. const data = request.formData();
D. const data = request.json();

Solution

  1. Step 1: Recognize that form data parsing is asynchronous

    Parsing form data requires awaiting the promise returned by request.formData().
  2. Step 2: Identify the correct syntax with await

    The correct syntax is const data = await request.formData(); to properly parse form data.
  3. Final Answer:

    const data = await request.formData(); -> Option B
  4. Quick Check:

    Form data parsing requires await request.formData() [OK]
Hint: Always await request.formData() to parse form data [OK]
Common Mistakes:
  • Not using await with request.formData()
  • Using request.json() to parse form data
  • Calling request.formData() without await
3. Given this Next.js route handler code snippet, what will be logged if the request body contains JSON {"name":"Alice"}?
export async function POST(request) {
  const data = await request.json();
  console.log(data.name);
  return new Response('OK');
}
medium
A. "Alice"
B. undefined
C. Error: Cannot read property 'name' of undefined
D. "{\"name\":\"Alice\"}"

Solution

  1. Step 1: Parse the JSON body using request.json()

    The request.json() method converts the JSON string into a JavaScript object.
  2. Step 2: Access the 'name' property from the parsed object

    Since the JSON contains {"name":"Alice"}, data.name will be "Alice".
  3. Final Answer:

    "Alice" -> Option A
  4. Quick Check:

    Parsed JSON object property access = "Alice" [OK]
Hint: request.json() returns object; access properties normally [OK]
Common Mistakes:
  • Expecting raw JSON string instead of parsed object
  • Not awaiting request.json() causing undefined
  • Trying to access property before parsing
4. Identify the error in this Next.js route handler code for parsing JSON:
export async function POST(request) {
  const data = request.json();
  return new Response(JSON.stringify(data));
}
medium
A. request.json() is not a valid method
B. Cannot use JSON.stringify on data
C. Missing await before request.json()
D. Response constructor requires status code

Solution

  1. Step 1: Check how request.json() is called

    The request.json() method returns a promise and must be awaited.
  2. Step 2: Identify missing await causing data to be a promise

    Without await, data is a promise, not the parsed object, causing incorrect response.
  3. Final Answer:

    Missing await before request.json() -> Option C
  4. Quick Check:

    Always await request.json() to get parsed data [OK]
Hint: Always await async parsing methods like request.json() [OK]
Common Mistakes:
  • Forgetting await before request.json()
  • Assuming request.json() returns data synchronously
  • Misunderstanding promise behavior in async functions
5. You want to handle a POST request in Next.js that can accept either JSON or form data. Which approach correctly parses the request body depending on its Content-Type header?
hard
A. Always use await request.json() regardless of Content-Type
B. Use await request.formData() for all POST requests
C. Use await request.text() and manually parse JSON or form data
D. Check request.headers.get('content-type') and use await request.json() for 'application/json', await request.formData() for 'multipart/form-data'

Solution

  1. Step 1: Identify the Content-Type header to determine data format

    The Content-Type header tells if the body is JSON or form data.
  2. Step 2: Use conditional parsing based on Content-Type

    Use await request.json() for 'application/json' and await request.formData() for 'multipart/form-data' or 'application/x-www-form-urlencoded'.
  3. Final Answer:

    Check content-type and parse accordingly with request.json() or request.formData() -> Option D
  4. Quick Check:

    Parse based on Content-Type header [OK]
Hint: Check Content-Type header to choose JSON or formData parsing [OK]
Common Mistakes:
  • Parsing all requests as JSON ignoring Content-Type
  • Parsing all requests as formData ignoring Content-Type
  • Not checking Content-Type before parsing