ما هو كود الحالة 423: مغلق؟ علامة ممنوع الإزعاج الرقمية

INEZA Felin-Michel

INEZA Felin-Michel

17 أكتوبر 2025

ما هو كود الحالة 423: مغلق؟ علامة ممنوع الإزعاج الرقمية

Apidog للمؤسسات

النشر على الخوادم المحلية

SSO و RBAC

متوافق مع SOC 2

استكشف Apidog للمؤسسات

أنت تتعاون مع زميل في مستند مهم. تفتحه لإجراء بعض التعديلات الحاسمة، وقبل أن تقوم بالحفظ مباشرة، تتلقى رسالة: "هذا المستند مقفل حاليًا بواسطة مستخدم آخر. يرجى المحاولة مرة أخرى لاحقًا." بدلاً من الإحباط، تشعر بالارتياح لأنك تجنبت للتو الكتابة فوق عمل زميلك بفضل نظام ذكي منع حدوث تعارض.

شبكة الأمان التعاونية هذه مدعومة بأحد رموز حالة HTTP الأكثر تخصصًا: 423 Locked. هذا الرمز لا يتعلق بالأمان أو الأذونات بالمعنى التقليدي؛ بل يتعلق بـ منع التعارضات في البيئات التعاونية.

رمز الحالة 423 هو طريقة الخادم للقول، "لا يمكنني السماح لك بتعديل هذا المورد الآن لأن شخصًا آخر يعمل عليه بالفعل. يرجى انتظار دورك." إنه المعادل الرقمي لعلامة "ممنوع الإزعاج" على باب غرفة فندق أو رؤية مؤشر شخص آخر يكتب بنشاط في مستند Google مشترك.

لكن لا تقلق، بنهاية هذا المنشور، لن تفهم ما يعنيه فحسب، بل ستعرف أيضًا لماذا يحدث، وكيفية إصلاحه، وكيفية تجنبه في المستقبل.

وإذا كنت مطورًا أو مختبرًا لواجهة برمجة التطبيقات (API)، فسأوضح لك كيف يمكن لأدوات مثل Apidog أن تجعل اكتشاف أخطاء 423 وحلها أسهل بكثير.

إذا كنت تعمل مع أدوات التحرير التعاوني، أو أنظمة التحكم في الإصدار، أو أي تطبيق قد يتعارض فيه العديد من المستخدمين مع بعضهم البعض، فإن فهم 423 له قيمة لا تصدق.

💡
إذا كنت تقوم بإنشاء أو اختبار واجهات برمجة التطبيقات التي تتعامل مع الوصول المتزامن، فأنت بحاجة إلى أداة يمكنها مساعدتك في محاكاة عدة مستخدمين. قم بتنزيل Apidog مجانًا؛ إنها منصة API شاملة تتيح لك اختبار آليات القفل والطلبات المتزامنة، مما يضمن تعامل تطبيقك مع التعاون بسلاسة.

الآن، دعنا نستكشف عالم قفل الموارد ورمز حالة HTTP 423.

المشكلة: مخاطر التحرير المتزامن

لفهم سبب وجود 423، نحتاج إلى فهم مشكلة التعديل المتزامن. تخيل مستخدمين، أليس وبوب، كلاهما يعدل نفس سجل العميل في نفس الوقت:

  1. 3:00:00 مساءً: يقوم كل من أليس وبوب بجلب سجل العميل. يظهر: {"name": "John", "email": "john@old.com"}
  2. 3:00:01 مساءً: تغير أليس البريد الإلكتروني إلى john@new.com وتقوم بالحفظ.
  3. 3:00:02 مساءً: يغير بوب الاسم إلى "Jonathan" ويقوم بالحفظ.
  4. النتيجة: حفظ بوب يكتب فوق تغيير البريد الإلكتروني لأليس لأنه كان يعمل بإصدار قديم. يظهر السجل النهائي: {"name": "Jonathan", "email": "john@old.com"} عمل أليس ضاع!

تسمى هذه المشكلة "مشكلة التحديث المفقود"، وهي مشكلة كلاسيكية في الأنظمة التعاونية. رمز الحالة 423 Locked هو جزء من الحل.

ماذا يعني HTTP 423 Locked بالفعل؟

رمز الحالة 423 Locked هو جزء من امتداد بروتوكول WebDAV (تأليف الإصدارات الموزعة على الويب) لـ HTTP. يشير إلى أن الطريقة (مثل PUT، DELETE، أو PROPPATCH) لا يمكن تنفيذها على المورد لأن المورد مقفل.

يجب أن يتضمن الرد معلومات حول القفل في نص الرد، عادةً باستخدام XML.

يبدو رد 423 نموذجيًا كما يلي:

HTTP/1.1 423 LockedContent-Type: application/xml; charset="utf-8"

<?xml version="1.0" encoding="utf-8"?>
<D:error xmlns:D="DAV:">
  <D:lock-token-submitted>
    <D:href>/workspace/doc.txt</D:href>
  </D:lock-token-submitted>
</D:error>

أو قد يكون هناك إصدار أكثر فائدة:

HTTP/1.1 423 LockedContent-Type: application/json
{
  "error": "ResourceLocked",
  "message": "This document is currently being edited by alice@example.com",
  "locked_until": "2024-01-15T14:30:00Z",
  "locked_by": "alice@example.com"
}

ينشأ هذا الرمز من بروتوكول WebDAV (تأليف الإصدارات الموزعة على الويب) وهو امتداد لـ HTTP يسمح للمستخدمين بتحرير وإدارة الملفات بشكل تعاوني على الخوادم البعيدة.

بشكل أبسط:

يحدث خطأ 423 Locked عندما يكون المورد (مثل ملف أو كائن أو سجل) "مقفلًا" حاليًا بواسطة شخص أو شيء آخر، وتحاول طلبك تعديله.

التعريف الرسمي (RFC 4918)

وفقًا لـ RFC 4918 (الذي يعرف WebDAV):

"رمز الحالة 423 (Locked) يعني أن مورد المصدر أو الوجهة لطريقة ما مقفل."

وهذا يعني:

باختصار: لا يُسمح لك بتعديله الآن.

السيناريوهات الشائعة التي قد ترى فيها 423 Locked

دعنا ننتقل إلى بعض الأمثلة الواقعية حيث يظهر رمز الحالة هذا في كل من تطوير الويب وتصميم واجهات برمجة التطبيقات (API).

1. التحرير المتزامن للملفات

إذا كان تطبيق الويب الخاص بك يسمح بتحميل الملفات أو تحديثها أو تحريرها بشكل تعاوني، فقد يستخدم آليات قفل لمنع التعارضات.

عندما يتم قفل ملف (لمنع الآخرين من إجراء تعديلات متزامنة)، فإن أي محاولة للكتابة فوقه تؤدي إلى 423.

مثال:

2. قفل سجلات قاعدة البيانات

في واجهات برمجة التطبيقات التي تتعامل مع البيانات الحساسة (مثل المخزون أو الخدمات المصرفية أو الجدولة)، غالبًا ما يتم قفل السجلات أثناء التحديثات لمنع حالات السباق.

إذا قامت معاملة واحدة بقفل سجل للتعديل وحاول طلب آخر تحديثه، فقد يحصل الطلب الثاني على 423 Locked.

3. أنظمة التحكم في الإصدار

في أنظمة مثل المنصات القائمة على Git أو برامج إدارة المحتوى التي تدعم تحديد إصدارات الملفات، قد يتم قفل ملف أو كيان حتى تكتمل عملية الدمج أو الموافقة.

قد تؤدي محاولة الدفع أو الحذف خلال تلك الفترة إلى استجابة 423.

4. تحديد معدل API أو قفل سير العمل

تطبق بعض واجهات برمجة التطبيقات أقفالًا مؤقتة للحفاظ على الترتيب في سير العمل.

على سبيل المثال، قد يتم قفل مورد أثناء معالجته أو التحقق من صحته، وحتى يتم ذلك، يتم حظر التغييرات الجديدة.

5. عمليات ملفات WebDAV

نظرًا لأن 423 ينشأ من WebDAV، فإن أي عمليات مثل COPY أو MOVE أو DELETE أو PUT على الموارد المقفلة تعيد هذه الحالة.

آلية القفل: كيف تعمل في الممارسة

يتبع قفل الموارد عادةً سير عمل محدد في الأنظمة المتوافقة مع WebDAV:

الخطوة 1: الحصول على القفل

قبل التحرير، يطلب العميل قفلًا على المورد باستخدام طريقة LOCK.

LOCK /documents/report.txt HTTP/1.1
Host: example.comTimeout: Second-3600Content-Type: application/xmlContent-Length: 150
<?xml version="1.0" encoding="utf-8"?>
<D:lockinfo xmlns:D="DAV:"><D:lockscope><D:exclusive/></D:lockscope><D:locktype><D:write/></D:locktype><D:owner>Alice</D:owner></D:lockinfo>

الخطوة 2: الخادم يمنح القفل

يستجيب الخادم بالنجاح ويوفر رمز قفل.

HTTP/1.1 200 OKContent-Type: application/xmlLock-Token: <urn:uuid:e71d4fae-5dec-22d6-fea5-00a0c91e6be4>
<?xml version="1.0" encoding="utf-8"?>
<D:prop xmlns:D="DAV:"><D:lockdiscovery><D:activelock><D:locktype><D:write/></D:locktype><D:lockscope><D:exclusive/></D:lockscope><D:depth>0</D:depth><D:owner>Alice</D:owner><D:timeout>Second-3600</D:timeout><D:locktoken><D:href>urn:uuid:e71d4fae-5dec-22d6-fea5-00a0c91e6be4</D:href></D:locktoken></D:activelock></D:lockdiscovery></D:prop>

الخطوة 3: بوب يحاول التعديل

بينما تحتفظ أليس بالقفل، يحاول بوب تعديل نفس المستند.

PUT /documents/report.txt HTTP/1.1Host: example.comContent-Type: text/plain
This is Bob's attempted change.

الخطوة 4: الخادم يعيد 423 Locked

يتحقق الخادم ويجد أن أليس لديها قفل حصري على المورد.

HTTP/1.1 423 LockedContent-Type: application/xml
<?xml version="1.0" encoding="utf-8"?>
<D:error xmlns:D="DAV:"><D:lock-token-submitted><D:href>/documents/report.txt</D:href></D:lock-token-submitted></D:error>

الخطوة 5: أليس تحرر القفل

عندما تنتهي أليس من التعديل، تقوم بإلغاء قفل المورد بشكل صريح.

UNLOCK /documents/report.txt HTTP/1.1
Host: example.comLock-Token: <urn:uuid:e71d4fae-5dec-22d6-fea5-00a0c91e6be4>

أنواع الأقفال في WebDAV

يدعم WebDAV استراتيجيات قفل مختلفة:

الأقفال الحصرية

يمكن لمستخدم واحد فقط الاحتفاظ بقفل حصري في كل مرة. هذا هو النوع الأكثر شيوعًا ويوفر أقوى منع للتعارضات.

الأقفال المشتركة

يمكن لعدة مستخدمين الاحتفاظ بأقفال مشتركة في وقت واحد، ولكن لا يمكن لأحد الحصول على قفل حصري طالما توجد أقفال مشتركة. هذا مفيد للقراءة مع منع التعديلات.

423 مقابل 409 Conflict: فهم الفرق

هذا تمييز مهم في عالم الوصول المتزامن:

تشبيه:

التطبيقات الحديثة خارج WebDAV

بينما نشأ 423 مع WebDAV، فإن مفهوم قفل الموارد يستخدم على نطاق واسع في التطبيقات الحديثة:

1. محررات المستندات التعاونية

تستخدم أدوات مثل Google Docs و Notion و Confluence آليات قفل مماثلة لإظهار متى يقوم شخص آخر بتحرير مستند بنشاط.

2. قفل قواعد البيانات والسجلات

تطبق العديد من التطبيقات قفلًا متشائمًا على مستوى قاعدة البيانات لمنع التحديثات المتزامنة لنفس السجل.

3. أنظمة مخزون التجارة الإلكترونية

عند إضافة عنصر إلى سلة التسوق الخاصة بك، قد يقوم النظام "بقفل" هذا المخزون مؤقتًا لمنع البيع الزائد أثناء إكمال عملية الشراء.

4. تحميل الملفات ومعالجتها

قد يقوم النظام بقفل ملف أثناء معالجته (على سبيل المثال، فحص الفيروسات، تحسين الصور) لمنع العمليات الأخرى من التدخل.

423 Locked في واجهات برمجة تطبيقات RESTful: هل يجب استخدامه؟

بالتأكيد، ولكن بحذر.

في تصميم واجهة برمجة تطبيقات REST، يمكن أن يكون استخدام 423 مفيدًا عندما:

ومع ذلك، إذا كنت تقوم بتصميم واجهات برمجة التطبيقات لاستخدام أوسع (خارج سياقات WebDAV)، فقد ترغب في إرجاع 409 Conflict بدلاً من ذلك لتعارضات الحالة العامة لأن 423 أكثر تحديدًا.

اختبار واجهات برمجة التطبيقات باستخدام Apidog

يعد اختبار سيناريوهات الوصول المتزامن أمرًا صعبًا ولكنه حاسم. يوفر Apidog إمكانيات ممتازة لاختبار سير العمل المعقد هذا.

باستخدام Apidog، يمكنك:

  1. محاكاة عدة مستخدمين: إنشاء طلبات مختلفة برموز مصادقة مختلفة لمحاكاة عمل أليس وبوب على نفس المورد.
  2. اختبار الحصول على القفل: إرسال طلبات LOCK (إذا كنت تختبر خادم WebDAV) أو نقطة نهاية القفل المخصصة الخاصة بك والتحقق من حصولك على الاستجابة الصحيحة مع رمز القفل.
  3. اختبار فرض القفل: جعل "أليس" تحصل على قفل، ثم جعل "بوب" يحاول تعديل المورد والتحقق من تلقيه استجابة 423 Locked.
  4. اختبار تحرير القفل: التحقق من أنه بعد أن تحرر "أليس" القفل، يمكن لـ "بوب" تعديل المورد بنجاح.
  5. أتمتة سيناريوهات القفل: إنشاء سيناريوهات اختبار تعمل تلقائيًا من خلال سير عمل القفل الكامل لضمان عمل منطق القفل الخاص بك بشكل صحيح.
button

هذا ذو قيمة خاصة للتطبيقات التي تتعامل مع البيانات الحساسة أو تتطلب ضمانات قوية للاتساق.

أفضل الممارسات لتطبيق القفل

لمطوري الخادم:

لمطوري العميل:

مفاهيم خاطئة شائعة حول HTTP 423

دعنا نبدد بعض الأساطير.

❌ "إنه خطأ في الأذونات."

لا، هذا هو 403 Forbidden. 423 مؤقت ومحدد للمورد.

❌ "يعني أن خادمي معطل."

لا. خادمك يعمل بشكل جيد؛ إنه يحمي موردًا فقط من التعديلات المتزامنة.

❌ "ينطبق فقط على WebDAV."

بينما تم تعريفه في WebDAV، تستخدم واجهات برمجة تطبيقات REST الحديثة أيضًا 423 عندما يناسب السياق.

المزالق والاعتبارات المحتملة

بينما القفل قوي، إلا أن له بعض التحديات:

  1. الجمود (Deadlocks): إذا قام عمليتان بقفل مورد ثم حاولتا قفل ما يمتلكه الآخر، فقد يحدث جمود.
  2. العبء الزائد على الأداء: إدارة الأقفال تضيف تعقيدًا ويمكن أن تؤثر على الأداء.
  3. تجربة المستخدم: يمكن أن يؤدي القفل سيئ التنفيذ إلى إحباط المستخدمين إذا تم حظرهم لفترات طويلة.
  4. الأقفال القديمة: إذا تعطل العميل دون تحرير قفله، يمكن أن يظل المورد مقفلاً حتى تنتهي المهلة.

الخاتمة: شبكة الأمان التعاونية

يمثل رمز حالة HTTP 423 Locked حلاً أنيقًا لمشكلة الوصول المتزامن المعقدة. بينما نشأ في بروتوكول WebDAV، فإن مفهوم قفل الموارد أساسي لبناء تطبيقات تعاونية موثوقة.

يعد فهم متى وكيفية استخدام القفل ومتى تستخدم استراتيجيات بديلة مثل التحكم التفاؤلي في التزامن مهارة أساسية للمطورين الذين يبنون أنظمة متعددة المستخدمين. رمز 423 ليس خطأ يجب الخوف منه؛ إنه ميزة تمكن التعاون الآمن.

من خلال تطبيق آليات القفل المناسبة والتعامل مع استجابات 423 بلطف، يمكنك بناء تطبيقات تمنع تلف البيانات وتوفر تجربة تعاون سلسة. وعندما تحتاج إلى اختبار هذه السيناريوهات المتزامنة المعقدة، تمنحك أداة قوية مثل Apidog التحكم والرؤية لضمان عمل منطق القفل الخاص بك بسلاسة في ظروف العالم الحقيقي.

button

ممارسة تصميم API في Apidog

اكتشف طريقة أسهل لبناء واستخدام واجهات برمجة التطبيقات