从0死磕全栈之深入理解 Next.js 中的 NextResponse:API 详解与实战示例

在 Next.js 的 App Router 架构中,NextResponse 是一个强大而灵活的工具,用于在 MiddlewareRoute Handlers (API 路由)等服务器端逻辑中构造 HTTP 响应。它扩展了原生的 Web Response API,并提供了许多便捷方法,如设置 Cookie、重定向、重写路径、返回 JSON 等。


1. 基础用法:NextResponse.next()

next() 方法常用于 Middleware 中,表示"继续处理后续路由",同时允许你修改请求或响应。

ts 复制代码
// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

export function middleware(request: NextRequest) {
  // 添加自定义请求头
  const newHeaders = new Headers(request.headers)
  newHeaders.set('x-custom-version', '1.0.0')

  return NextResponse.next({
    request: {
      headers: newHeaders,
    },
  })
}

✅ 用途:权限校验、A/B 测试、国际化路由等场景中"放行"请求。


NextResponse 提供了对 Set-Cookie 响应头的便捷操作。

ts 复制代码
// middleware.ts
import { NextResponse } from 'next/server'

export function middleware() {
  const response = NextResponse.next()
  response.cookies.set('show-banner', 'false', {
    path: '/home',
    httpOnly: true,
    secure: process.env.NODE_ENV === 'production',
  })
  return response
}

📌 生成的响应头:

ini 复制代码
Set-Cookie: show-banner=false; Path=/home; HttpOnly; Secure
ts 复制代码
const bannerCookie = response.cookies.get('show-banner')
// 返回 { name: 'show-banner', value: 'false', Path: '/home' } 或 undefined
ts 复制代码
// 获取指定名称的所有 Cookie(支持多值)
const experiments = response.cookies.getAll('experiments')

// 获取所有 Cookie
const allCookies = response.cookies.getAll()
ts 复制代码
const deleted = response.cookies.delete('show-banner') // 返回 boolean

💡 注意:delete() 实际是设置该 Cookie 的过期时间为过去,从而让浏览器删除它。


3. 返回 JSON 响应:NextResponse.json()

在 Route Handler(如 app/api/user/route.ts)中非常常用:

ts 复制代码
// app/api/user/route.ts
import { NextResponse } from 'next/server'

export async function GET() {
  return NextResponse.json(
    { id: 1, name: 'Alice' },
    { status: 200 }
  )
}

export async function POST() {
  return NextResponse.json(
    { error: 'Invalid input' },
    { status: 400 }
  )
}

✅ 自动设置 Content-Type: application/json


4. 重定向:NextResponse.redirect()

用于身份验证、URL 规范化等场景。

ts 复制代码
// middleware.ts
import { NextResponse } from 'next/server'

export function middleware(request: NextRequest) {
  const isLoggedIn = false // 假设未登录

  if (!isLoggedIn) {
    const loginUrl = new URL('/login', request.url)
    loginUrl.searchParams.set('from', request.nextUrl.pathname)
    return NextResponse.redirect(loginUrl)
  }

  return NextResponse.next()
}

🔁 会返回 307 Temporary Redirect(或 308,取决于方法)。


5. 路径重写:NextResponse.rewrite()

与重定向不同,重写不会改变浏览器地址栏 URL,但会内部代理到另一个路径。

ts 复制代码
// middleware.ts
import { NextResponse } from 'next/server'

export function middleware(request: NextRequest) {
  if (request.nextUrl.pathname === '/secret') {
    // 用户访问 /secret,但实际渲染 /internal-page 的内容
    return NextResponse.rewrite(new URL('/internal-page', request.url))
  }

  return NextResponse.next()
}

🌐 适用于:动态内容代理、A/B 测试、隐藏真实路径等。


6. 完整示例:带认证的 Middleware

结合多种能力,实现一个简单的登录拦截器:

ts 复制代码
// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

const PUBLIC_PATHS = ['/login', '/signup', '/about']

export function middleware(request: NextRequest) {
  const path = request.nextUrl.pathname
  const token = request.cookies.get('auth-token')?.value

  // 公开路径直接放行
  if (PUBLIC_PATHS.some(p => path.startsWith(p))) {
    return NextResponse.next()
  }

  // 未登录则重定向到登录页
  if (!token) {
    const loginUrl = new URL('/login', request.url)
    loginUrl.searchParams.set('from', path)
    return NextResponse.redirect(loginUrl)
  }

  // 已登录:设置安全头并继续
  const response = NextResponse.next()
  response.cookies.set('last-visited', path, { maxAge: 60 * 60 }) // 1小时
  return response
}

export const config = {
  matcher: ['/((?!api|_next/static|_next/image|favicon.ico).*)'],
}

总结

NextResponse 是 Next.js App Router 中处理服务器响应的核心工具,其主要能力包括:

方法 用途
next() 继续路由(Middleware)
json() 返回 JSON 响应
redirect() 重定向用户
rewrite() 内部重写路径(不改变 URL)
cookies.set/get/delete 操作响应 Cookie

通过合理使用这些方法,你可以构建高性能、安全且用户体验良好的 Next.js 应用。

相关推荐
于慨15 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz15 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶15 小时前
前端交互规范(Web 端)
前端
CHU72903515 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing15 小时前
Page-agent MCP结构
前端·人工智能
王霸天15 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航15 小时前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界16 小时前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc16 小时前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说16 小时前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js