الفرق بين المراجعتين لصفحة: «Next.js/next server»
لا ملخص تعديل |
لا ملخص تعديل |
||
سطر 10: | سطر 10: | ||
** <code>buildId</code>: من النوع (<code>string || undefined</code>) | ** <code>buildId</code>: من النوع (<code>string || undefined</code>) | ||
** <code>defaultLocale</code>: من النوع (<code>string || undefined</code>) | ** <code>defaultLocale</code>: من النوع (<code>string || undefined</code>) | ||
** <code>domainLocale</code> : | ** <code>domainLocale</code>: | ||
*** <code>defaultLocale</code>: من النوع (<code>string</code>) | ***<code>defaultLocale</code>: من النوع (<code>string</code>) | ||
*** <code>domain</code>: من النوع (<code>string</code>) | *** <code>domain</code>: من النوع (<code>string</code>) | ||
*** <code>http</code>: من النوع (<code>boolean || undefined</code>) | *** <code>http</code>: من النوع (<code>boolean || undefined</code>) | ||
*** <code>locales</code>: من النوع (<code>string[] || undefined</code>) | *** <code>locales</code>: من النوع (<code>string[] || undefined</code>) | ||
*** <code>locale</code>: من النوع | *** <code>locale</code>: من النوع (<code>string || undefined</code>) | ||
*** <code>url</code> : من النوع (<code>URL</code>) | *** <code>url</code>: من النوع (<code>URL</code>) | ||
* <code>ip</code>: من النوع (<code>string || undefined</code>) ويمتلك عنوان IP للطلب. وتزوّدك به منصة الاستضافة. | * <code>ip</code>: من النوع (<code>string || undefined</code>) ويمتلك عنوان IP للطلب. وتزوّدك به منصة الاستضافة. | ||
* <code>geo</code>: وتضم معلومات عن الموقع الجغرافي من الطلب <code>request</code>، وتتضمن هذه المعلومات التي تحصل عليها من منصة الاستضافة ما يلي: | * <code>geo</code>: وتضم معلومات عن الموقع الجغرافي من الطلب <code>request</code>، وتتضمن هذه المعلومات التي تحصل عليها من منصة الاستضافة ما يلي: | ||
** <code>city</code> : من النوع (<code>string || undefined</code>). | **<code>city</code>: من النوع (<code>string || undefined</code>). | ||
** <code>country</code>: من النوع (<code>string || undefined</code>). | ** <code>country</code>: من النوع (<code>string || undefined</code>). | ||
** <code>region</code>: من النوع (<code>string || undefined</code>). | ** <code>region</code>: من النوع (<code>string || undefined</code>). | ||
** <code>latitude</code>: من النوع (<code>string || undefined</code>). | ** <code>latitude</code>: من النوع (<code>string || undefined</code>). | ||
** <code>longitude</code>: من النوع | ** <code>longitude</code>: من النوع (<code>string || undefined</code>). | ||
يمكنك استخدام الكائن <code>NextRequest</code> كبديل مباشر عن الواجهة الأصلية <code>Request</code> مما يمنحك تحكمًا أكبر بطريقة تعديل الطلب. يمكن إدراج <code>NextRequest</code> من المكوّن | يمكنك استخدام الكائن <code>NextRequest</code> كبديل مباشر عن الواجهة الأصلية <code>Request</code> مما يمنحك تحكمًا أكبر بطريقة تعديل الطلب. يمكن إدراج <code>NextRequest</code> من المكوّن <code>next/server</code> كالتالي:<syntaxhighlight lang="javascript"> | ||
import type { NextRequest } from 'next/server' | import type { NextRequest } from 'next/server' | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 63: | سطر 63: | ||
* <code>()next</code>: يُعيد نسخة عن الصنف <code>NextResponse</code> تستأنف سلسلة الأداة الوسطية. | * <code>()next</code>: يُعيد نسخة عن الصنف <code>NextResponse</code> تستأنف سلسلة الأداة الوسطية. | ||
ولاستخدام التوابع السابقة، لا بد من إ<u>عادة الكائن</u> . يمكنك إدراج <code>NextResponse</code> من المكوّن <code>next/server</code> كالتالي:<syntaxhighlight lang="javascript"> | ولاستخدام التوابع السابقة، لا بد من إ<u>عادة الكائن</u>. يمكنك إدراج <code>NextResponse</code> من المكوّن <code>next/server</code> كالتالي:<syntaxhighlight lang="javascript"> | ||
import { NextResponse } from 'next/server' | import { NextResponse } from 'next/server' | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 75: | سطر 75: | ||
** <code>version</code>: من النوع (<code>string || undefined</code>)، يعيد إصدار المتصفح ويُحدد ديناميكيًا. | ** <code>version</code>: من النوع (<code>string || undefined</code>)، يعيد إصدار المتصفح ويُحدد ديناميكيًا. | ||
* <code>device</code>: ويضم: | * <code>device</code>: ويضم: | ||
** <code>model</code>: من النوع (<code>string || undefined</code>)، يعيد نوع الجهاز ويُحدد ديناميكيًا. | **<code>model</code>: من النوع (<code>string || undefined</code>)، يعيد نوع الجهاز ويُحدد ديناميكيًا. | ||
** <code>type</code>: من النوع (<code>string || undefined</code>)، يعيد نوع المتصفح، ويمكن أن يحمل إحدى القيم التالية | ** <code>type</code>: من النوع (<code>string || undefined</code>)، يعيد نوع المتصفح، ويمكن أن يحمل إحدى القيم التالية <code>console</code> أو <code>mobile</code> أو <code>tablet</code> أو <code>smarttv</code> أو <code>wearable</code> أو <code>embedded</code> أو <code>undefined</code>. | ||
** <code>vendor</code>: من النوع (<code>string || undefined</code>)، يُعيد مُصنّع لوحة الجهاز ويُحدَّد ديناميكيًا. | ** <code>vendor</code>: من النوع (<code>string || undefined</code>)، يُعيد مُصنّع لوحة الجهاز ويُحدَّد ديناميكيًا. | ||
* <code>engine</code>: ويضم: | * <code>engine</code>: ويضم: | ||
**<code>name</code>: (<code>string || undefined</code>) يحدد نوع المحرّك الذي بُني عليه المتصفح، ويأخذ أحد القيم التالية:<code>Amaya</code> أو <code>Blink</code> | **<code>name</code>: (<code>string || undefined</code>) يحدد نوع المحرّك الذي بُني عليه المتصفح، ويأخذ أحد القيم التالية:<code>Amaya</code> أو <code>Blink</code> أو <code>EdgeHTML</code> أو <code>Flow</code> أو <code>Gecko</code> أو <code>Goanna</code> <code>iCab</code> أو <code>KHTML</code> <code>Links</code> أو <code>Lynx</code> أو <code>NetFront</code> أو <code>NetSurf</code> أو <code>Presto</code> أو <code>Tasman</code> أو <code>Trident</code> أو <code>w3m</code> أو <code>WebKit</code> أو <code>vendor</code> أو <code>undefined</code>. | ||
** <code>version</code>:من النوع (<code>string || undefined</code>)، يعيد إصدار محرّك المتصفح ويُحدَّد ديناميكيًا وقد يكون غير محدد <code>undefined</code>. | ** <code>version</code>:من النوع (<code>string || undefined</code>)، يعيد إصدار محرّك المتصفح ويُحدَّد ديناميكيًا وقد يكون غير محدد <code>undefined</code>. | ||
* <code>os</code>: ويضم: | * <code>os</code>: ويضم: | ||
** <code>name</code>: من النوع (<code>string || undefined</code>)، يعيد اسم نظام التشغيل وقد يكون غير محدد <code>undefined</code>. | **<code>name</code>: من النوع (<code>string || undefined</code>)، يعيد اسم نظام التشغيل وقد يكون غير محدد <code>undefined</code>. | ||
** <code>version</code>: من النوع | ** <code>version</code>: من النوع (<code>string || undefined</code>)، ويعيد إصدار نظام التشغيل، وقد يكون غير محدد <code>undefined</code>. | ||
* <code>cpu</code>: ويضم: | * <code>cpu</code>: ويضم: | ||
** <code>architecture</code>: من النوع (<code>string || undefined</code>)، يعيد معمارية المعالج، ويأخذ احد القيم التالية: <code>68k</code> أو | **<code>architecture</code>: من النوع (<code>string || undefined</code>)، يعيد معمارية المعالج، ويأخذ احد القيم التالية: <code>68k</code> أو <code>amd64</code> أو <code>arm</code> أو <code>arm64</code> أو <code>armhf</code> أو <code>avr</code> أو <code>ia32</code> أو <code>ia64</code> أو <code>irix</code> أو <code>irix64</code> أو <code>mips</code> أو <code>mips64</code> أو <code>pa-risc</code> أو <code>ppc</code> أو <code>sparc</code> أو <code>sparc64</code> أو غير محدد <code>undefined</code>. | ||
يمكنك إدراج <code>userAgent</code> من المكوّن <code>next/server</code> كالتالي:<syntaxhighlight lang="javascript"> | يمكنك إدراج <code>userAgent</code> من المكوّن <code>next/server</code> كالتالي:<syntaxhighlight lang="javascript"> | ||
سطر 102: | سطر 102: | ||
== الأسئلة الأكثر شيوعًا == | == الأسئلة الأكثر شيوعًا == | ||
=== لماذا يستخدم التابع <code>redirect</code> رمزي الحالة 307 | === لماذا يستخدم التابع <code>redirect</code> رمزي الحالة 307 و308؟ === | ||
قد تلاحظ استخدام رمز الحالة | قد تلاحظ استخدام رمز الحالة <code>307</code> لإعادة التوجه المؤقت و <code>308</code> لإعادة التوجه الدائم مع <code>()redirect</code>. وعلى الرغم من استخدام الرمزين <code>302</code> و <code>301</code> على الترتيب تقليديًا، إلا أن العديد من المتصفحات قد غيرت نوع طلب إعادة التوجه من <code>POST</code> إلى <code>GET</code> عند استخدام الرمز <code>302</code> بغض النظر عن أصول نوع الطلب. | ||
فلو أخذنا المثال التالي عن إعادة التوجيه من <code>users/</code> إلى <code>people/</code>، ستجد أنك لو أجريت طلبًا من النوع <code>POST</code> إلى <code>users/</code> لإنشاء مستخدم جديد يتوافق مع رمز الحالة <code>302</code>، سيتغير نوع الطلب إلى <code>GET</code>، وهذا غير منطقي لأنك تحتاج إلى طلب من النوع <code>POST</code> إلى <code>people/</code> وليس من النوع <code>GET</code>. | فلو أخذنا المثال التالي عن إعادة التوجيه من <code>users/</code> إلى <code>people/</code>، ستجد أنك لو أجريت طلبًا من النوع <code>POST</code> إلى <code>users/</code> لإنشاء مستخدم جديد يتوافق مع رمز الحالة <code>302</code>، سيتغير نوع الطلب إلى <code>GET</code>، وهذا غير منطقي لأنك تحتاج إلى طلب من النوع <code>POST</code> إلى <code>people/</code> وليس من النوع <code>GET</code>. | ||
سطر 112: | سطر 112: | ||
* <code>307</code>: ستحفظ عملية إعادة التوجيه المؤقت الطلب على الشكل <code>POST</code>. | * <code>307</code>: ستحفظ عملية إعادة التوجيه المؤقت الطلب على الشكل <code>POST</code>. | ||
يستخدم التابع <code>()redirect</code> رمز الحالة <code>307</code> افتراضيًا بدلًا من <code>302</code>ويعني ذلك أن طلبك سيُحفظ دائمًا على أنه من النوع <code>POST</code>. وإن كنت تريد أن ترد باستجابة من النوع | يستخدم التابع <code>()redirect</code> رمز الحالة <code>307</code> افتراضيًا بدلًا من <code>302</code>ويعني ذلك أن طلبك سيُحفظ دائمًا على أنه من النوع <code>POST</code>. وإن كنت تريد أن ترد باستجابة من النوع <code>GET</code> على طلب <code>POST</code> استخدم رمز الحالة <code>303</code>. | ||
=== كيف يمكنني الوصول إلى متغيرات الحالة؟ === | === كيف يمكنني الوصول إلى متغيرات الحالة؟ === |
مراجعة 15:05، 18 يوليو 2022
يقدّم المكوّن next/server
مجموعة من الدوال المساعدة تعمل على الخادم فقط وتستخدم مع الأداة الوسطية ووجهات API الحدودية
الكائن NextRequest
وهو امتداد للواجهة الأصلية Request
بعد إضافة التوابع والخاصيات التالية:
cookies
: قائمة مترابطة Map تضم ملفات تعريف الارتباط المأخوذة من الطلبRequest
.nextUrl
: وتضم كائن موسّع ومُحلّل يمنحك الوصول إلى خاصيات محددة في مثلpathname
وbasePath
وtrailingSlash
وi18n
. بالإضافة إلى الخاصيات التالية:basePath
: من النوع (string
)buildId
: من النوع (string || undefined
)defaultLocale
: من النوع (string || undefined
)domainLocale
:defaultLocale
: من النوع (string
)domain
: من النوع (string
)http
: من النوع (boolean || undefined
)locales
: من النوع (string[] || undefined
)locale
: من النوع (string || undefined
)url
: من النوع (URL
)
ip
: من النوع (string || undefined
) ويمتلك عنوان IP للطلب. وتزوّدك به منصة الاستضافة.geo
: وتضم معلومات عن الموقع الجغرافي من الطلبrequest
، وتتضمن هذه المعلومات التي تحصل عليها من منصة الاستضافة ما يلي:city
: من النوع (string || undefined
).country
: من النوع (string || undefined
).region
: من النوع (string || undefined
).latitude
: من النوع (string || undefined
).longitude
: من النوع (string || undefined
).
يمكنك استخدام الكائن NextRequest
كبديل مباشر عن الواجهة الأصلية Request
مما يمنحك تحكمًا أكبر بطريقة تعديل الطلب. يمكن إدراج NextRequest
من المكوّن next/server
كالتالي:
import type { NextRequest } from 'next/server'
الكائن NextFetchEvent
يوسّع هذا الكائن الكائن الأصلي FetchEvent
ويضم التابع ()waitUntil
. يمكن استخدام التابع ()waitUntil
لإطالة وقت تنفيذ الدالة إن كانت هناك أعمال أخرى قيد التنفيذ في الخلفية.
import { NextResponse } from 'next/server'
import type { NextFetchEvent, NextRequest } from 'next/server'
export async function middleware(req: NextRequest, event: NextFetchEvent) {
event.waitUntil(
fetch('https://my-analytics-platform.com', {
method: 'POST',
body: JSON.stringify({ pathname: req.nextUrl.pathname }),
})
)
return NextResponse.next()
}
يمكن إدراج NextFetchEvent
من المكوّن next/server
كالتالي:
import type { NextFetchEvent } from 'next/server'
الصنف NextResponse
يوسِّع هذا الصنف الواجهة الأصلية Response
من خلال التوابع والخاصيات التالية:
التوابع العامة
تُتاح هذه التوابع للاستعمال ضمن نسخ عن الصنف NextResponse
. إذ يمكنك إنتاج نسخ عن الصنف وفقًا لحالة الاستخدام وإسنادها إلى متغير ثم الوصول من خلاله إلى التوابع العامة التالية:
cookies
: قائمة مترابطة Map تضم ملفات تعريف الارتباط المأخوذة من الطلبRequest
.
التوابع الساكنة
إليك التوابع الساكنة المتاحة للاستخدام المباشر من خلال NextResponse
:
()redirect
: يُعيد نسخة عن الصنفNextResponse
مع مجموعة إعادة توجيه.()rewrite
: يُعيد نسخة عن الصنفNextResponse
مع مجموعة إعادة كتابة.()next
: يُعيد نسخة عن الصنفNextResponse
تستأنف سلسلة الأداة الوسطية.
ولاستخدام التوابع السابقة، لا بد من إعادة الكائن. يمكنك إدراج NextResponse
من المكوّن next/server
كالتالي:
import { NextResponse } from 'next/server'
الدالة المساعدة userAgent
تسمح هذه الدالة بالتفاعل مع كائن عميل المستخدم user agent القادم مع الطلب. أخذت الدالة من الكائن الأصلي Request
وهي ميزة مخصصة لها الخاصيات التالية:
isBot
: من النوع (boolean
) وتحدد إن كان مصدر الطلب برنامج آلي bot معروف.browser
: ويضم:name
: من النوع (string || undefined
)، يعيد اسم المتصفح.version
: من النوع (string || undefined
)، يعيد إصدار المتصفح ويُحدد ديناميكيًا.
device
: ويضم:model
: من النوع (string || undefined
)، يعيد نوع الجهاز ويُحدد ديناميكيًا.type
: من النوع (string || undefined
)، يعيد نوع المتصفح، ويمكن أن يحمل إحدى القيم التاليةconsole
أوmobile
أوtablet
أوsmarttv
أوwearable
أوembedded
أوundefined
.vendor
: من النوع (string || undefined
)، يُعيد مُصنّع لوحة الجهاز ويُحدَّد ديناميكيًا.
engine
: ويضم:name
: (string || undefined
) يحدد نوع المحرّك الذي بُني عليه المتصفح، ويأخذ أحد القيم التالية:Amaya
أوBlink
أوEdgeHTML
أوFlow
أوGecko
أوGoanna
iCab
أوKHTML
Links
أوLynx
أوNetFront
أوNetSurf
أوPresto
أوTasman
أوTrident
أوw3m
أوWebKit
أوvendor
أوundefined
.version
:من النوع (string || undefined
)، يعيد إصدار محرّك المتصفح ويُحدَّد ديناميكيًا وقد يكون غير محددundefined
.
os
: ويضم:name
: من النوع (string || undefined
)، يعيد اسم نظام التشغيل وقد يكون غير محددundefined
.version
: من النوع (string || undefined
)، ويعيد إصدار نظام التشغيل، وقد يكون غير محددundefined
.
cpu
: ويضم:architecture
: من النوع (string || undefined
)، يعيد معمارية المعالج، ويأخذ احد القيم التالية:68k
أوamd64
أوarm
أوarm64
أوarmhf
أوavr
أوia32
أوia64
أوirix
أوirix64
أوmips
أوmips64
أوpa-risc
أوppc
أوsparc
أوsparc64
أو غير محددundefined
.
يمكنك إدراج userAgent
من المكوّن next/server
كالتالي:
import { userAgent } from 'next/server'
import { NextRequest, NextResponse, userAgent } from 'next/server'
export function middleware(request: NextRequest) {
const url = request.nextUrl
const { device } = userAgent(request)
const viewport = device.type === 'mobile' ? 'mobile' : 'desktop'
url.searchParams.set('viewport', viewport)
return NextResponse.rewrite(url)
}
الأسئلة الأكثر شيوعًا
لماذا يستخدم التابع redirect
رمزي الحالة 307 و308؟
قد تلاحظ استخدام رمز الحالة 307
لإعادة التوجه المؤقت و 308
لإعادة التوجه الدائم مع ()redirect
. وعلى الرغم من استخدام الرمزين 302
و 301
على الترتيب تقليديًا، إلا أن العديد من المتصفحات قد غيرت نوع طلب إعادة التوجه من POST
إلى GET
عند استخدام الرمز 302
بغض النظر عن أصول نوع الطلب.
فلو أخذنا المثال التالي عن إعادة التوجيه من users/
إلى people/
، ستجد أنك لو أجريت طلبًا من النوع POST
إلى users/
لإنشاء مستخدم جديد يتوافق مع رمز الحالة 302
، سيتغير نوع الطلب إلى GET
، وهذا غير منطقي لأنك تحتاج إلى طلب من النوع POST
إلى people/
وليس من النوع GET
.
إنّ القصد من إدخال رمز الحالة هو الإشارة إلى أن نوع الطلب قد حُفظ كطلب POST
.
302
: ستغير عملية إعادة التوجيه المؤقت الطلب منPOST
إلىGET
.307
: ستحفظ عملية إعادة التوجيه المؤقت الطلب على الشكلPOST
.
يستخدم التابع ()redirect
رمز الحالة 307
افتراضيًا بدلًا من 302
ويعني ذلك أن طلبك سيُحفظ دائمًا على أنه من النوع POST
. وإن كنت تريد أن ترد باستجابة من النوع GET
على طلب POST
استخدم رمز الحالة 303
.
كيف يمكنني الوصول إلى متغيرات الحالة؟
بإمكانك استخدام الملف process.env
للوصول إلى متغيرات البيئة من الأداة الوسطية الحدودية وسيجري التحقق من المتغيرات أثناء تنفيذ الأمر next build
:
الشيفرة التالية قابلة للتنفيذ | الشيفرة التالية غير قابلة للتنفيذ |
---|---|
console.log(process.env.MY_ENV_VARIABLE)
|
const getEnv = name => process.env[name]
|
const { MY_ENV_VARIABLE } = process.env
|
الشيفرة التالية غير قابلة للتنفيذ |
const { "MY-ENV-VARIABLE": MY_ENV_VARIABLE } = process.env
|
اقرأ أيضًا
المصادر
- الصفحة Next/server من توثيق Next.js الرسمي.