مدیریت ریدایرکت‌ها در Next.js – از ریدایرکت ساده تا مقیاس‌پذیر با Proxy

ریدایرکت‌ها در Next.js می‌توانند در سطح کلاینت، سرور، فایل پیکربندی یا Proxy مدیریت شوند. این مقاله انواع روش‌های ریدایرکت، کاربردهای هرکدام، و راهکارهای مقیاس‌پذیر برای مدیریت هزاران مسیر را بررسی می‌کند — از useRouter تا Bloom Filter.

redirectpermanentRedirectuseRouterProxy

~3 دقیقه مطالعه • بروزرسانی ۶ آبان ۱۴۰۴

انواع ریدایرکت در Next.js


APIکاربردمحل استفادهکد وضعیت
redirectریدایرکت بعد از رویداد یا تغییرکامپوننت سرور، Server Action، Route Handler307 یا 303
permanentRedirectریدایرکت دائمی بعد از تغییر URLکامپوننت سرور، Server Action، Route Handler308
useRouterناوبری سمت کلاینتکامپوننت کلاینتندارد
redirects در next.config.jsریدایرکت بر اساس مسیر ورودیفایل پیکربندی307 یا 308
NextResponse.redirectریدایرکت شرطی قبل از پاسخProxyدلخواه

استفاده از redirect


برای ریدایرکت بعد از ایجاد یا تغییر داده:

'use server'

import { redirect } from 'next/navigation'
import { revalidatePath } from 'next/cache'

export async function createPost(id: string) {
  revalidatePath('/posts')
  redirect(`/post/${id}`)
}

در Server Action، کد 303 ارسال می‌شود. توجه: redirect یک خطا پرتاب می‌کند و باید خارج از try/catch استفاده شود.


استفاده از permanentRedirect


برای ریدایرکت دائمی بعد از تغییر مسیر اصلی:

'use server'

import { permanentRedirect } from 'next/navigation'
import { revalidateTag } from 'next/cache'

export async function updateUsername(username: string) {
  revalidateTag('username')
  permanentRedirect(`/profile/${username}`)
}

استفاده از useRouter در کلاینت


برای ناوبری در رویدادهای کلاینت:

'use client'

import { useRouter } from 'next/navigation'

export default function Page() {
  const router = useRouter()

  return (
    <button onClick={() => router.push('/dashboard')}>
      Dashboard
    </button>
  )
}

ریدایرکت در next.config.js


برای ریدایرکت‌های از پیش تعریف‌شده:

export async function redirects() {
  return [
    { source: '/about', destination: '/', permanent: true },
    { source: '/blog/:slug', destination: '/news/:slug', permanent: true },
  ]
}

مناسب برای تغییر ساختار URL یا مهاجرت مسیرها. محدودیت: در Vercel حداکثر 1024 ریدایرکت.


ریدایرکت شرطی با Proxy


برای ریدایرکت بر اساس وضعیت احراز هویت یا شرایط خاص:

import { NextResponse, NextRequest } from 'next/server'
import { authenticate } from 'auth-provider'

export function proxy(request: NextRequest) {
  if (!authenticate(request)) {
    return NextResponse.redirect(new URL('/login', request.url))
  }
  return NextResponse.next()
}

مدیریت ریدایرکت‌های حجیم با Map


ذخیره مسیرها در JSON یا پایگاه داده:

{
  "/old": { "destination": "/new", "permanent": true },
  "/blog/post-old": { "destination": "/blog/post-new", "permanent": true }
}

خواندن مسیر از Edge Config یا Redis و ریدایرکت بر اساس آن.


بهینه‌سازی با Bloom Filter


برای بررسی سریع وجود مسیر در لیست ریدایرکت:

  • استفاده از Bloom Filter برای بررسی اولیه
  • در صورت وجود، واکشی داده از Route Handler
  • ارسال ریدایرکت با کد مناسب

جمع‌بندی


Next.js ابزارهای متنوعی برای مدیریت ریدایرکت‌ها ارائه می‌دهد — از ریدایرکت ساده تا راهکارهای مقیاس‌پذیر با Proxy و Bloom Filter. با انتخاب روش مناسب، می‌توانید تجربه کاربری روان، امن و قابل نگهداری بسازید.


نوشته و پژوهش شده توسط دکتر شاهین صیامی