മലയാളം

Next.js മിഡിൽവെയർ ഉപയോഗിച്ച് ഇൻകമിംഗ് അഭ്യർത്ഥനകൾ തടസ്സപ്പെടുത്താനും മാറ്റം വരുത്താനും പഠിക്കുക. പ്രാമാണീകരണം, അംഗീകാരം, റീഡയറക്ഷൻ, എ/ബി ടെസ്റ്റിംഗ് എന്നിവ പ്രായോഗിക ഉദാഹരണങ്ങളിലൂടെ നടപ്പിലാക്കാം.

Next.js മിഡിൽവെയർ: ഡൈനാമിക് ആപ്ലിക്കേഷനുകൾക്കായി അഭ്യർത്ഥന തടസ്സപ്പെടുത്തുന്നതിൽ വൈദഗ്ദ്ധ്യം നേടുക

Next.js മിഡിൽവെയർ നിങ്ങളുടെ റൂട്ടുകളിൽ എത്തുന്നതിന് മുമ്പ് ഇൻകമിംഗ് അഭ്യർത്ഥനകളെ തടസ്സപ്പെടുത്താനും പരിഷ്കരിക്കാനും വഴക്കമുള്ളതും ശക്തവുമായ ഒരു മാർഗ്ഗം നൽകുന്നു. പ്രകടനം ഒപ്റ്റിമൈസ് ചെയ്യുമ്പോൾ തന്നെ പ്രാമാണീകരണം, അംഗീകാരം മുതൽ റീഡയറക്ഷൻ, എ/ബി ടെസ്റ്റിംഗ് വരെയുള്ള നിരവധി സവിശേഷതകൾ നടപ്പിലാക്കാൻ ഈ കഴിവ് നിങ്ങളെ സഹായിക്കുന്നു. ഈ സമഗ്രമായ ഗൈഡ് Next.js മിഡിൽവെയറിൻ്റെ പ്രധാന ആശയങ്ങളിലൂടെ നിങ്ങളെ കൊണ്ടുപോകുകയും അത് എങ്ങനെ ഫലപ്രദമായി ഉപയോഗിക്കാമെന്ന് കാണിക്കുകയും ചെയ്യും.

എന്താണ് Next.js മിഡിൽവെയർ?

Next.js-ലെ മിഡിൽവെയർ ഒരു അഭ്യർത്ഥന പൂർത്തിയാകുന്നതിന് മുമ്പ് പ്രവർത്തിക്കുന്ന ഒരു ഫംഗ്‌ഷനാണ്. ഇത് നിങ്ങളെ ഇനിപ്പറയുന്നവയ്ക്ക് അനുവദിക്കുന്നു:

മിഡിൽവെയർ ഫംഗ്‌ഷനുകൾ നിങ്ങളുടെ പ്രോജക്റ്റിൻ്റെ റൂട്ടിലുള്ള middleware.ts (അല്ലെങ്കിൽ middleware.js) ഫയലിൽ നിർവചിച്ചിരിക്കുന്നു. അവ നിങ്ങളുടെ ആപ്ലിക്കേഷനിലെ എല്ലാ റൂട്ടുകൾക്കുമായി അല്ലെങ്കിൽ കോൺഫിഗർ ചെയ്യാവുന്ന മാച്ചറുകളെ അടിസ്ഥാനമാക്കി നിർദ്ദിഷ്ട റൂട്ടുകൾക്കായി എക്സിക്യൂട്ട് ചെയ്യപ്പെടുന്നു.

പ്രധാന ആശയങ്ങളും പ്രയോജനങ്ങളും

അഭ്യർത്ഥന ഒബ്ജക്റ്റ് (Request Object)

request ഒബ്ജക്റ്റ് ഇൻകമിംഗ് അഭ്യർത്ഥനയെക്കുറിച്ചുള്ള വിവരങ്ങളിലേക്ക് ആക്സസ് നൽകുന്നു, ഇതിൽ ഉൾപ്പെടുന്നു:

പ്രതികരണ ഒബ്ജക്റ്റ് (Response Object)

അഭ്യർത്ഥനയുടെ ഫലം നിയന്ത്രിക്കുന്നതിന് മിഡിൽവെയർ ഫംഗ്‌ഷനുകൾ ഒരു Response ഒബ്ജക്റ്റ് തിരികെ നൽകുന്നു. നിങ്ങൾക്ക് ഇനിപ്പറയുന്ന പ്രതികരണങ്ങൾ ഉപയോഗിക്കാം:

മാച്ചറുകൾ (Matchers)

നിങ്ങളുടെ മിഡിൽവെയർ ഏത് റൂട്ടുകളിൽ പ്രയോഗിക്കണമെന്ന് വ്യക്തമാക്കാൻ മാച്ചറുകൾ നിങ്ങളെ അനുവദിക്കുന്നു. റെഗുലർ എക്സ്പ്രഷനുകളോ പാത്ത് പാറ്റേണുകളോ ഉപയോഗിച്ച് നിങ്ങൾക്ക് മാച്ചറുകൾ നിർവചിക്കാം. ഇത് നിങ്ങളുടെ മിഡിൽവെയർ ആവശ്യമുള്ളപ്പോൾ മാത്രം പ്രവർത്തിക്കുന്നുവെന്ന് ഉറപ്പാക്കുന്നു, പ്രകടനം മെച്ചപ്പെടുത്തുകയും ഓവർഹെഡ് കുറയ്ക്കുകയും ചെയ്യുന്നു.

എഡ്ജ് റൺടൈം (Edge Runtime)

Next.js മിഡിൽവെയർ എഡ്ജ് റൺടൈമിൽ പ്രവർത്തിക്കുന്നു, ഇത് നിങ്ങളുടെ ഉപയോക്താക്കൾക്ക് അടുത്ത് വിന്യസിക്കാൻ കഴിയുന്ന ഒരു ഭാരം കുറഞ്ഞ JavaScript റൺടൈം പരിതസ്ഥിതിയാണ്. ഈ സാമീപ്യം ലേറ്റൻസി കുറയ്ക്കുകയും നിങ്ങളുടെ ആപ്ലിക്കേഷൻ്റെ മൊത്തത്തിലുള്ള പ്രകടനം മെച്ചപ്പെടുത്തുകയും ചെയ്യുന്നു, പ്രത്യേകിച്ച് ആഗോളതലത്തിൽ വിതരണം ചെയ്യപ്പെട്ട ഉപയോക്താക്കൾക്ക്. എഡ്ജ് റൺടൈം Vercel-ൻ്റെ എഡ്ജ് നെറ്റ്‌വർക്കിലും മറ്റ് അനുയോജ്യമായ പ്ലാറ്റ്‌ഫോമുകളിലും ലഭ്യമാണ്. എഡ്ജ് റൺടൈമിന് ചില പരിമിതികളുണ്ട്, പ്രത്യേകിച്ച് Node.js API-കളുടെ ഉപയോഗത്തിൽ.

പ്രായോഗിക ഉദാഹരണങ്ങൾ: മിഡിൽവെയർ ഫീച്ചറുകൾ നടപ്പിലാക്കൽ

1. പ്രാമാണീകരണം (Authentication)

ഉപയോക്താക്കൾക്ക് ലോഗിൻ ചെയ്യേണ്ട റൂട്ടുകൾ പരിരക്ഷിക്കാൻ പ്രാമാണീകരണ മിഡിൽവെയർ ഉപയോഗിക്കാം. കുക്കികൾ ഉപയോഗിച്ച് പ്രാമാണീകരണം എങ്ങനെ നടപ്പിലാക്കാം എന്നതിൻ്റെ ഒരു ഉദാഹരണം ഇതാ:


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

export function middleware(request: NextRequest) {
 const token = request.cookies.get('auth_token');

 if (!token) {
 return NextResponse.redirect(new URL('/login', request.url))
 }

 return NextResponse.next()
}

export const config = {
 matcher: ['/dashboard/:path*'],
}

ഈ മിഡിൽവെയർ ഒരു auth_token കുക്കിയുടെ സാന്നിധ്യം പരിശോധിക്കുന്നു. കുക്കി കണ്ടെത്തിയില്ലെങ്കിൽ, ഉപയോക്താവിനെ /login പേജിലേക്ക് റീഡയറക്ട് ചെയ്യും. config.matcher ഈ മിഡിൽവെയർ /dashboard-ന് കീഴിലുള്ള റൂട്ടുകൾക്ക് മാത്രമേ പ്രവർത്തിക്കാവൂ എന്ന് വ്യക്തമാക്കുന്നു.

ആഗോള കാഴ്ചപ്പാട്: വിവിധ പ്രാമാണീകരണ രീതികളെ (ഉദാ. OAuth, JWT) പിന്തുണയ്‌ക്കുന്നതിനും വിവിധ ഐഡൻ്റിറ്റി പ്രൊവൈഡർമാരുമായി (ഉദാ. Google, Facebook, Azure AD) സംയോജിപ്പിക്കുന്നതിനും പ്രാമാണീകരണ ലോജിക് ക്രമീകരിക്കുക. ഇത് വിവിധ പ്രദേശങ്ങളിൽ നിന്നുള്ള ഉപയോക്താക്കളെ പരിഗണിക്കാൻ സഹായിക്കും.

2. അംഗീകാരം (Authorization)

ഉപയോക്തൃ റോളുകൾ അല്ലെങ്കിൽ അനുമതികൾ അടിസ്ഥാനമാക്കി ഉറവിടങ്ങളിലേക്കുള്ള പ്രവേശനം നിയന്ത്രിക്കാൻ അംഗീകാര മിഡിൽവെയർ ഉപയോഗിക്കാം. ഉദാഹരണത്തിന്, നിങ്ങൾക്ക് ഒരു അഡ്മിൻ ഡാഷ്‌ബോർഡ് ഉണ്ടാകാം, അത് നിർദ്ദിഷ്ട ഉപയോക്താക്കൾക്ക് മാത്രമേ ആക്‌സസ് ചെയ്യാൻ കഴിയൂ.


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

export async function middleware(request: NextRequest) {
 const token = request.cookies.get('auth_token');

 if (!token) {
 return NextResponse.redirect(new URL('/login', request.url))
 }

 // Example: Fetch user roles from an API (replace with your actual logic)
 const userResponse = await fetch('https://api.example.com/userinfo', {
 headers: {
 Authorization: `Bearer ${token}`,
 },
 });
 const userData = await userResponse.json();

 if (userData.role !== 'admin') {
 return NextResponse.redirect(new URL('/unauthorized', request.url))
 }

 return NextResponse.next()
}

export const config = {
 matcher: ['/admin/:path*'],
}

ഈ മിഡിൽവെയർ ഉപയോക്താവിൻ്റെ റോൾ വീണ്ടെടുക്കുകയും അവർക്ക് admin റോൾ ഉണ്ടോയെന്ന് പരിശോധിക്കുകയും ചെയ്യുന്നു. ഇല്ലെങ്കിൽ, അവരെ ഒരു /unauthorized പേജിലേക്ക് റീഡയറക്ട് ചെയ്യും. ഈ ഉദാഹരണം ഒരു പ്ലെയ്‌സ്‌ഹോൾഡർ API എൻഡ്‌പോയിൻ്റ് ഉപയോഗിക്കുന്നു. `https://api.example.com/userinfo` എന്നതിന് പകരം നിങ്ങളുടെ യഥാർത്ഥ പ്രാമാണീകരണ സെർവർ എൻഡ്‌പോയിൻ്റ് ഉപയോഗിക്കുക.

ആഗോള കാഴ്ചപ്പാട്: ഉപയോക്തൃ ഡാറ്റ കൈകാര്യം ചെയ്യുമ്പോൾ ഡാറ്റാ സ്വകാര്യതാ നിയന്ത്രണങ്ങളെക്കുറിച്ച് (ഉദാ. GDPR, CCPA) ശ്രദ്ധിക്കുക. തന്ത്രപ്രധാനമായ വിവരങ്ങൾ പരിരക്ഷിക്കുന്നതിനും പ്രാദേശിക നിയമങ്ങൾ പാലിക്കുന്നുണ്ടെന്ന് ഉറപ്പാക്കുന്നതിനും ഉചിതമായ സുരക്ഷാ നടപടികൾ നടപ്പിലാക്കുക.

3. റീഡയറക്ഷൻ (Redirection)

ഉപയോക്താക്കളുടെ സ്ഥാനം, ഭാഷ, അല്ലെങ്കിൽ മറ്റ് മാനദണ്ഡങ്ങൾ എന്നിവ അടിസ്ഥാനമാക്കി അവരെ റീഡയറക്ട് ചെയ്യാൻ റീഡയറക്ഷൻ മിഡിൽവെയർ ഉപയോഗിക്കാം. ഉദാഹരണത്തിന്, ഉപയോക്താക്കളെ അവരുടെ IP വിലാസത്തെ അടിസ്ഥാനമാക്കി നിങ്ങളുടെ വെബ്സൈറ്റിൻ്റെ പ്രാദേശികവൽക്കരിച്ച പതിപ്പിലേക്ക് റീഡയറക്ട് ചെയ്യാം.


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

export function middleware(request: NextRequest) {
 const country = request.geo?.country || 'US'; // Default to US if geo-location fails

 if (country === 'DE') {
 return NextResponse.redirect(new URL('/de', request.url))
 }

 if (country === 'FR') {
 return NextResponse.redirect(new URL('/fr', request.url))
 }

 return NextResponse.next()
}

export const config = {
 matcher: ['/'],
}

ഈ മിഡിൽവെയർ ഉപയോക്താവിൻ്റെ IP വിലാസത്തെ അടിസ്ഥാനമാക്കി രാജ്യം പരിശോധിച്ച് അവരെ വെബ്സൈറ്റിൻ്റെ ഉചിതമായ പ്രാദേശികവൽക്കരിച്ച പതിപ്പിലേക്ക് (ജർമ്മനിക്ക് /de, ഫ്രാൻസിന് /fr) റീഡയറക്ട് ചെയ്യുന്നു. ജിയോ-ലൊക്കേഷൻ പരാജയപ്പെട്ടാൽ, അത് യുഎസ് പതിപ്പിലേക്ക് ഡിഫോൾട്ട് ചെയ്യുന്നു. ഇത് ജിയോ പ്രോപ്പർട്ടി ലഭ്യമാകുന്നതിനെ ആശ്രയിച്ചിരിക്കുന്നു എന്നത് ശ്രദ്ധിക്കുക (ഉദാഹരണത്തിന്, Vercel-ൽ വിന്യസിക്കുമ്പോൾ).

ആഗോള കാഴ്ചപ്പാട്: നിങ്ങളുടെ വെബ്സൈറ്റ് ഒന്നിലധികം ഭാഷകളെയും കറൻസികളെയും പിന്തുണയ്ക്കുന്നുവെന്ന് ഉറപ്പാക്കുക. ഉപയോക്താക്കൾക്ക് അവരുടെ ഇഷ്ടപ്പെട്ട ഭാഷയോ പ്രദേശമോ സ്വമേധയാ തിരഞ്ഞെടുക്കാനുള്ള ഓപ്ഷൻ നൽകുക. ഓരോ ലൊക്കേലിനും ഉചിതമായ തീയതി, സമയ ഫോർമാറ്റുകൾ ഉപയോഗിക്കുക.

4. എ/ബി ടെസ്റ്റിംഗ് (A/B Testing)

ഒരു പേജിൻ്റെ വിവിധ വകഭേദങ്ങളിലേക്ക് ഉപയോക്താക്കളെ ക്രമരഹിതമായി നിയോഗിച്ചും അവരുടെ പെരുമാറ്റം ട്രാക്ക് ചെയ്തും എ/ബി ടെസ്റ്റിംഗ് നടപ്പിലാക്കാൻ മിഡിൽവെയർ ഉപയോഗിക്കാം. അതിൻ്റെ ലളിതമായ ഒരു ഉദാഹരണം ഇതാ:


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

function getRandomVariant() {
 return Math.random() < 0.5 ? 'A' : 'B';
}

export function middleware(request: NextRequest) {
 let variant = request.cookies.get('variant')?.value;

 if (!variant) {
 variant = getRandomVariant();
 const response = NextResponse.next();
 response.cookies.set('variant', variant);
 return response;
 }

 if (variant === 'B') {
 return NextResponse.rewrite(new URL('/variant-b', request.url));
 }

 return NextResponse.next();
}

export const config = {
 matcher: ['/'],
}

ഈ മിഡിൽവെയർ ഉപയോക്താക്കളെ 'A' അല്ലെങ്കിൽ 'B' വേരിയൻ്റിലേക്ക് നിയോഗിക്കുന്നു. ഒരു ഉപയോക്താവിന് ഇതിനകം ഒരു variant കുക്കി ഇല്ലെങ്കിൽ, ഒന്ന് ക്രമരഹിതമായി നിയോഗിക്കുകയും സജ്ജമാക്കുകയും ചെയ്യുന്നു. 'B' വേരിയൻ്റിലേക്ക് നിയോഗിക്കപ്പെട്ട ഉപയോക്താക്കളെ /variant-b പേജിലേക്ക് മാറ്റിയെഴുതുന്നു. ഏത് വേരിയൻ്റാണ് കൂടുതൽ ഫലപ്രദമെന്ന് നിർണ്ണയിക്കാൻ നിങ്ങൾ ഓരോ വേരിയൻ്റിൻ്റെയും പ്രകടനം ട്രാക്ക് ചെയ്യേണ്ടതുണ്ട്.

ആഗോള കാഴ്ചപ്പാട്: എ/ബി ടെസ്റ്റുകൾ രൂപകൽപ്പന ചെയ്യുമ്പോൾ സാംസ്കാരിക വ്യത്യാസങ്ങൾ പരിഗണിക്കുക. ഒരു മേഖലയിൽ നന്നായി പ്രവർത്തിക്കുന്നത് മറ്റൊരു മേഖലയിലെ ഉപയോക്താക്കളിൽ പ്രതിധ്വനിക്കണമെന്നില്ല. നിങ്ങളുടെ എ/ബി ടെസ്റ്റിംഗ് പ്ലാറ്റ്ഫോം വിവിധ പ്രദേശങ്ങളിലെ സ്വകാര്യതാ നിയന്ത്രണങ്ങൾക്ക് അനുസൃതമാണെന്ന് ഉറപ്പാക്കുക.

5. ഫീച്ചർ ഫ്ലാഗുകൾ (Feature Flags)

പുതിയ കോഡ് വിന്യസിക്കാതെ തന്നെ നിങ്ങളുടെ ആപ്ലിക്കേഷനിലെ ഫീച്ചറുകൾ പ്രവർത്തനക്ഷമമാക്കാനോ പ്രവർത്തനരഹിതമാക്കാനോ ഫീച്ചർ ഫ്ലാഗുകൾ നിങ്ങളെ അനുവദിക്കുന്നു. ഒരു ഉപയോക്താവിന് അവരുടെ യൂസർ ഐഡി, സ്ഥാനം, അല്ലെങ്കിൽ മറ്റ് മാനദണ്ഡങ്ങൾ എന്നിവ അടിസ്ഥാനമാക്കി ഒരു നിർദ്ദിഷ്ട ഫീച്ചറിലേക്ക് പ്രവേശനം വേണോ എന്ന് നിർണ്ണയിക്കാൻ മിഡിൽവെയർ ഉപയോഗിക്കാം.


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

export async function middleware(request: NextRequest) {
 // Example: Fetch feature flags from an API
 const featureFlagsResponse = await fetch('https://api.example.com/featureflags', {
 headers: {
 'X-User-Id': 'user123',
 },
 });
 const featureFlags = await featureFlagsResponse.json();

 if (featureFlags.new_feature_enabled) {
 // Enable the new feature
 return NextResponse.next();
 } else {
 // Disable the new feature (e.g., redirect to an alternative page)
 return NextResponse.redirect(new URL('/alternative-page', request.url));
 }
}

export const config = {
 matcher: ['/new-feature'],
}

ഈ മിഡിൽവെയർ ഒരു API-ൽ നിന്ന് ഫീച്ചർ ഫ്ലാഗുകൾ നേടുകയും new_feature_enabled ഫ്ലാഗ് സജ്ജീകരിച്ചിട്ടുണ്ടോയെന്ന് പരിശോധിക്കുകയും ചെയ്യുന്നു. അങ്ങനെയാണെങ്കിൽ, ഉപയോക്താവിന് /new-feature പേജ് ആക്സസ് ചെയ്യാൻ കഴിയും. അല്ലാത്തപക്ഷം, അവരെ ഒരു /alternative-page-ലേക്ക് റീഡയറക്ട് ചെയ്യും.

ആഗോള കാഴ്ചപ്പാട്: വിവിധ പ്രദേശങ്ങളിലെ ഉപയോക്താക്കൾക്ക് പുതിയ ഫീച്ചറുകൾ ക്രമേണ പുറത്തിറക്കാൻ ഫീച്ചർ ഫ്ലാഗുകൾ ഉപയോഗിക്കുക. ഒരു വലിയ പ്രേക്ഷകരിലേക്ക് ഫീച്ചർ പുറത്തിറക്കുന്നതിന് മുമ്പ് പ്രകടനം നിരീക്ഷിക്കാനും എന്തെങ്കിലും പ്രശ്നങ്ങൾ പരിഹരിക്കാനും ഇത് നിങ്ങളെ അനുവദിക്കുന്നു. കൂടാതെ, നിങ്ങളുടെ ഫീച്ചർ ഫ്ലാഗിംഗ് സിസ്റ്റം ആഗോളതലത്തിൽ സ്കെയിൽ ചെയ്യുന്നുണ്ടെന്നും ഉപയോക്താവിൻ്റെ സ്ഥാനം പരിഗണിക്കാതെ സ്ഥിരമായ ഫലങ്ങൾ നൽകുന്നുണ്ടെന്നും ഉറപ്പാക്കുക. ഫീച്ചർ റോളൗട്ടുകൾക്കായി പ്രാദേശിക റെഗുലേറ്ററി നിയന്ത്രണങ്ങൾ പരിഗണിക്കുക.

വിപുലമായ സാങ്കേതിക വിദ്യകൾ

മിഡിൽവെയർ ചെയിനിംഗ് (Chaining Middleware)

ഒരു അഭ്യർത്ഥനയിൽ ഒരു കൂട്ടം പ്രവർത്തനങ്ങൾ നടത്താൻ നിങ്ങൾക്ക് ഒന്നിലധികം മിഡിൽവെയർ ഫംഗ്ഷനുകൾ ഒരുമിച്ച് ബന്ധിപ്പിക്കാൻ കഴിയും. സങ്കീർണ്ണമായ ലോജിക്കുകളെ ചെറുതും കൂടുതൽ കൈകാര്യം ചെയ്യാവുന്നതുമായ മൊഡ്യൂളുകളായി വിഭജിക്കാൻ ഇത് ഉപയോഗപ്രദമാകും.


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

export function middleware(request: NextRequest) {
 const response = NextResponse.next();

 // First middleware function
 const token = request.cookies.get('auth_token');
 if (!token) {
 return NextResponse.redirect(new URL('/login', request.url))
 }

 // Second middleware function
 response.headers.set('x-middleware-custom', 'value');

 return response;
}

export const config = {
 matcher: ['/dashboard/:path*'],
}

ഈ ഉദാഹരണം ഒന്നിൽ രണ്ട് മിഡിൽവെയറുകൾ കാണിക്കുന്നു. ആദ്യത്തേത് പ്രാമാണീകരണം നടത്തുന്നു, രണ്ടാമത്തേത് ഒരു കസ്റ്റം ഹെഡർ സജ്ജീകരിക്കുന്നു.

എൻവയോൺമെൻ്റ് വേരിയബിളുകൾ ഉപയോഗിക്കൽ

API കീകൾ, ഡാറ്റാബേസ് ക്രെഡൻഷ്യലുകൾ തുടങ്ങിയ തന്ത്രപ്രധാനമായ വിവരങ്ങൾ നിങ്ങളുടെ മിഡിൽവെയർ ഫംഗ്ഷനുകളിൽ ഹാർഡ്‌കോഡ് ചെയ്യുന്നതിന് പകരം എൻവയോൺമെൻ്റ് വേരിയബിളുകളിൽ സംഭരിക്കുക. ഇത് സുരക്ഷ മെച്ചപ്പെടുത്തുകയും നിങ്ങളുടെ ആപ്ലിക്കേഷൻ്റെ കോൺഫിഗറേഷൻ നിയന്ത്രിക്കുന്നത് എളുപ്പമാക്കുകയും ചെയ്യുന്നു.


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

const API_KEY = process.env.API_KEY;

export async function middleware(request: NextRequest) {
 const response = await fetch('https://api.example.com/data', {
 headers: {
 'X-API-Key': API_KEY,
 },
 });

 // ...
}

export const config = {
 matcher: ['/data'],
}

ഈ ഉദാഹരണത്തിൽ, API_KEY ഒരു എൻവയോൺമെൻ്റ് വേരിയബിളിൽ നിന്ന് വീണ്ടെടുക്കുന്നു.

പിശകുകൾ കൈകാര്യം ചെയ്യൽ (Error Handling)

അപ്രതീക്ഷിത പിശകുകൾ നിങ്ങളുടെ ആപ്ലിക്കേഷൻ ക്രാഷ് ചെയ്യുന്നത് തടയാൻ നിങ്ങളുടെ മിഡിൽവെയർ ഫംഗ്ഷനുകളിൽ ശക്തമായ എറർ ഹാൻഡ്‌ലിംഗ് നടപ്പിലാക്കുക. ഒഴിവാക്കലുകൾ പിടിക്കാനും പിശകുകൾ ഉചിതമായി ലോഗ് ചെയ്യാനും try...catch ബ്ലോക്കുകൾ ഉപയോഗിക്കുക.


// middleware.ts
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'

export async function middleware(request: NextRequest) {
 try {
 const response = await fetch('https://api.example.com/data');
 // ...
 } catch (error) {
 console.error('Error fetching data:', error);
 return NextResponse.error(); // Or redirect to an error page
 }
}

export const config = {
 matcher: ['/data'],
}

മികച്ച രീതികൾ

സാധാരണ പ്രശ്നങ്ങൾ പരിഹരിക്കൽ

ഉപസംഹാരം

ഡൈനാമിക്, വ്യക്തിഗത വെബ് ആപ്ലിക്കേഷനുകൾ നിർമ്മിക്കുന്നതിനുള്ള ഒരു ശക്തമായ ഉപകരണമാണ് Next.js മിഡിൽവെയർ. അഭ്യർത്ഥന തടസ്സപ്പെടുത്തുന്നതിൽ വൈദഗ്ദ്ധ്യം നേടുന്നതിലൂടെ, പ്രാമാണീകരണവും അംഗീകാരവും മുതൽ റീഡയറക്ഷൻ, എ/ബി ടെസ്റ്റിംഗ് വരെ നിങ്ങൾക്ക് വിപുലമായ സവിശേഷതകൾ നടപ്പിലാക്കാൻ കഴിയും. ഈ ഗൈഡിൽ പറഞ്ഞിരിക്കുന്ന മികച്ച രീതികൾ പിന്തുടരുന്നതിലൂടെ, നിങ്ങളുടെ ആഗോള ഉപയോക്തൃ അടിത്തറയുടെ ആവശ്യങ്ങൾ നിറവേറ്റുന്ന ഉയർന്ന പ്രകടനമുള്ളതും സുരക്ഷിതവും അളക്കാവുന്നതുമായ ആപ്ലിക്കേഷനുകൾ സൃഷ്ടിക്കാൻ നിങ്ങൾക്ക് Next.js മിഡിൽവെയർ ഉപയോഗിക്കാം. നിങ്ങളുടെ Next.js പ്രോജക്റ്റുകളിൽ പുതിയ സാധ്യതകൾ തുറക്കുന്നതിനും അസാധാരണമായ ഉപയോക്തൃ അനുഭവങ്ങൾ നൽകുന്നതിനും മിഡിൽവെയറിൻ്റെ ശക്തി സ്വീകരിക്കുക.