الفرق بين المراجعتين ل"Node.js/net"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
ط (استبدال النص - '\[\[تصنيف:(.*)\]\]' ب'{{SUBPAGENAME}}')
 
(10 مراجعات متوسطة بواسطة مستخدمين اثنين آخرين غير معروضة)
سطر 1: سطر 1:
وحدة Net
+
<noinclude>{{DISPLAYTITLE: الوحدة Net في Node.js}}</noinclude>
 
 
 
مؤشر الاستقرار: 2 - مستقر.
 
مؤشر الاستقرار: 2 - مستقر.
  
توفر الوحدة net واجهة تطبيقات لشبكة اتصال غير متزامن لإنشاء خوادم قائمة على تدفق TCP أو IPC (net.createServer()‎) والعملاء (net.createConnection()‎).
+
توفر الوحدة <code>net</code> واجهة تطبيقات لشبكة اتصال غير متزامن لإنشاء خوادم قائمة على تدفق اتصالات TCP أو IPC أي (<code>net.createServer()‎</code>) والعملاء (<code>net.createConnection()</code>‎).
 
 
ويمكن الوصول إليه باستخدام:
 
  
 +
ويمكن الوصول إليه باستخدام:<syntaxhighlight lang="javascript">
 
const net = require('net');
 
const net = require('net');
 +
</syntaxhighlight>
 +
==دعم اتصالات IPC==
 +
تدعم وحدة <code>net</code> اتصالات IPC بواسطة الأنابيب المُسماة (named pipes) في ويندوز، أو مقابس مجالات يونكس (UNIX domain sockets) في أنظمة التشغيل الأخرى.
 +
===تحديد مسارات اتصالات IPC===
 +
تحتاج التوابع <code>net.connect()</code>‎ و <code>net.createConnection()‎</code> و <code>server.listen()</code>‎ و <code>socket.connect()‎</code> المعامل <code>path</code> لتحديد نهايات اتصالات IPC.
  
== دعم اتصالات IPC ==
+
يُعرف النطاق المحلي في UNIX بنطاق UNIX. ويكون المسار هو اسم مسار نظام الملفات. ويجري اقتصاصها إلى حجم يساوي <code>sizeof(sockaddr_un.sun_path)-1</code>، والذي يختلف من نظام تشغيل إلى آخر بين 91 و 107 بايت. القيم النموذجية هي 107 في نظام لينكس و 103 في نظام macOS. ويخضع المسار لنفس اصطلاحات التسمية وفحص الأذونات بنفس كيفية إنشاء ملف. إذا أُنشئ مقبس مجال UNIX (الذي يكون مرئياً كمسار نظام ملف) واستُخدم بالاقتران مع أحد تجريديات واجهات تطبيقات Node.js مثل <code>net.createServer()‎</code>، سينقطع ارتباطه كجزء من <code>server.close()</code>‎. من ناحية أخرى، إذا أُنشئ واستُخدم خارج هذه التجريديات، سوف يحتاج المستخدم لإزالته يدويًا. وينطبق الشيء نفسه عند إنشاء المسار من قِبَل واجهات تطبيقات Node.js ولكن البرنامج يتعطل فجأة. وباختصار، سيظهر مقبس مجال UNIX في نظام الملفات تم إنشاءه بنجاح، وسوف يستمر حتى يقطع ارتباطه.
تدعم وحدة net اتصالات IPC بواسطة الأنابيب المُسماة (named pipes) في Windows، أو مقابس مجال UNIX في أنظمة التشغيل الأخرى.
 
 
 
=== تحديد مسارات اتصالات IPC ===
 
تحتاج التوابع net.connect()‎ و net.createConnection()‎ و server.listen()‎ و socket.connect()‎ المعامل path لتحديد نهايات اتصالات IPC.
 
  
يُعرف النطاق المحلي في UNIX بنطاق UNIX. ويكون المسار هو اسم مسار نظام الملفات. ويجري اقتصاصها إلى حجم يساوي sizeof(sockaddr_un.sun_path)-1، والذي يختلف من نظام تشغيل إلى آخر بين 91 و 107 بايت. القيم النموذجية هي 107 في نظام Linux و 103 في نظام macOS. ويخضع المسار لنفس اصطلاحات التسمية وفحص الأذونات بنفس كيفية إنشاء ملف. إذا أُنشئ مقبس مجال UNIX (الذي يكون مرئياً كمسار نظام ملف) واستُخدم بالاقتران مع أحد تجريديات واجهات تطبيقات Node.js مثل net.createServer()‎، سينقطع ارتباطه كجزء من server.close()‎. من ناحية أخرى، إذا أُنشئ واستُخدم خارج هذه التجريديات، سوف يحتاج المستخدم لإزالته يدوياً. وينطبق الشيء نفسه عند إنشاء المسار من قِبَل واجهات تطبيقات Node.js ولكن البرنامج يتعطل فجأة. وباختصار، سيظهر مقبس مجال UNIX في نظام الملفات تو إنشاءه بنجاح، وسوف يستمر حتى يقطع ارتباطه.
+
في ويندوز، يتحقق النطاق المحلي باستخدام أنبوب مُسمّى. يجب أن يشير المسار إلى مُدخل في ‎<code>\\?\pipe\</code>‎ أو ‎<code>\\.\pipe\</code>‎. مسموح بأي حروف، ولكن قد يجري هذا الأخير بعض المعالجة لأسماء الأنابيب مثل أن يُترجم متواليات <code>..</code> . على الرغم من كيف يمكن أن تبدو، فإن مجال أسماء الأنابيب مسطحة. لن تستمر الأنابيب. وتُزال عند إغلاق آخر مرجع إليها. على عكس مقابس مجال UNIX، يُغلق ويندوز الأنابيب ويُزيلها عند انتهاء العملية المالكة.
  
في Windows، يتحقق النطاق المحلي باستخدام أنبوب مُسمّى. يجب أن يشير المسار إلى مُدخل في ‎\\?\pipe\‎ أو ‎\\.\pipe\‎. مسموح بأي حروف، ولكن قد يجري هذا الأخير بعض المعالجة لأسماء الأنابيب مثل أن يُترجم متواليات.. . على الرغم من كيف يمكن أن تبدو، فإن مجال أسماء الأنابيب مسطحة. لن تستمر الأنابيب. وتُزال عند إغلاق آخر مرجع إليها. على عكس مقابس مجال UNIX، يُغلق Windows الأنابيب ويُزيلها عند انتهاء العملية المالكة.
+
يتطلب الهروب من سلسلة JavaScript مسارات محددة باستخدام شرطة هروب مائلة عكسية <code>\</code> إضافية مثل:<syntaxhighlight lang="javascript">
 
+
net.createServer().listen(
يتطلب الهروب من سلسلة JavaScript مسارات محددة باستخدام شرطة هروب مائلة عكسية \إضافية مثل:
+
  path.join('\\\\?\\pipe', process.cwd(), 'myctl'));
 
+
</syntaxhighlight>
== الصنف: <code>net.Server</code> ==
+
==الصنف <code>net.Server</code>==
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
 
يستخدم هذا الصنف لإنشاء خادم TCP أو IPC.
 
يستخدم هذا الصنف لإنشاء خادم TCP أو IPC.
 +
===<code>new net.Server([options][, connectionListener])‎</code>===
 +
* <code>options</code> ‏‎[[JavaScript/Object|<Object>]]‎: راجع <code>net.createServer([options][, connectionListener])‎</code>.
 +
* <code>connectionListener‏</code> [[JavaScript/Function|<Function>]]: ضبط الدالة تلقائيًا كمستمع للحدث '<code>connection</code>'.
  
=== <code>new net.Server([options][, connectionListener])‎</code> ===
+
* القيمة المُعادة: من النوع <code><net.Server></code>.
القيمة المُعادة: من النوع <net.Server>.
+
ويُعد <code>net.Server</code> هو <code>[[Node.js/events|EventEmitter]]</code> مع الأحداث التالية:
 
+
===الحدث <code>'close'</code>===
راجع <code>net.createServer([options][, connectionListener])‎</code>.
 
 
 
ويُعد net.Server هو EventEmitter مع الأحداث التالية:
 
 
 
=== الحدث: 'close' ===
 
 
أُضيف مع الإصدار: v0.5.0.
 
أُضيف مع الإصدار: v0.5.0.
  
 
يُطلَق عند إغلاق الخادم. لاحظ أنه في حالة وجود اتصالات، لا ينطلق هذا الحدث حتى إنهاء كافة الاتصالات.
 
يُطلَق عند إغلاق الخادم. لاحظ أنه في حالة وجود اتصالات، لا ينطلق هذا الحدث حتى إنهاء كافة الاتصالات.
 
+
===الحدث <code>'connection'</code>===
=== الحدث: 'connection' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code><net.Socket></code>: وهو كائن الاتصال.
<net.Socket>: وهو كائن الاتصال.
+
يُطلَق عند إجراء اتصال جديد. ويكون <code>socket</code> مثيل <code>net.Socket</code>.
 
+
===الحدث <code>'error'</code>===
يُطلَق عند إجراء اتصال جديد. ويكون socket مثيل net.Socket.
 
 
 
=== الحدث: 'error' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* من النوع <code>[[JavaScript/Error|<Error>]]</code>.
من النوع <Error>.
+
يُطلَق عند حدوث خطأ ما. على عكس <code>net.Socket</code> لا يصدر الحدث <code>'close'</code> مباشرة بعد هذا الحدث إلا إذا اُستدعيَ <code>server.close()</code>‎ يدويًا. راجع المثال في شرح <code>server.listen()</code>‎.
 
+
===الحدث: <code>'listening'</code>===
يُطلَق عند حدوث خطأ ما. على عكس net.Socket لا يصدر الحدث 'close' مباشرة بعد هذا الحدث إلا إذا اُستدعيَ server.close()‎ يدويًا. راجع المثال في شرح server.listen()‎.
 
 
 
=== الحدث: 'listening' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
يُطلَق عند ربط الخادم بعد استدعاء server.listen()‎.
+
يُطلَق عند ربط الخادم بعد استدعاء <code>server.listen()‎</code>.
 
+
===<code>server.address()‎</code>===
=== <code>server.address()‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* القيمة المُعادة: من النوع [[JavaScript/Object|<Object>]] أو [[JavaScript/String|<string>]].
القيمة المُعادة: من النوع <Object>.
+
يعيد العنوان <code>address</code> المنضم واسم عائلة العنوان <code>family</code> ومنفذ الخادم <code>port</code> كما يذكره نظام التشغيل إذا كان يستمع إلى مقبس IP (وهو يفيد في العثور على أي منفذ الذي عُيّن عند الحصول على عنوان مُعيَّن من قِبل نظام التشغيل): ‎<code>{ port: 12346, family: 'IPv4', address: '127.0.0.1' }</code>‎.
 
 
يعيد العنوان address المنضم واسم أسرة العنوان family ومنفذ الخادم port كما يذكره نظام التشغيل إذا كان يستمع إلى مقبس IP (وهو يفيد في العثور على أي منفذ الذي عُيّن عند الحصول على عنوان مُعيَّن من قِبل نظام التشغيل): ‎{ port: 12346, family: 'IPv4', address: '127.0.0.1' }‎.
 
  
 
بالنسبة لخادم يستمع إلى أنابيب أو مقبس نطاق UNIX، يُعاد الاسم كسلسلة نصية.
 
بالنسبة لخادم يستمع إلى أنابيب أو مقبس نطاق UNIX، يُعاد الاسم كسلسلة نصية.
  
على سبيل المثال:
+
على سبيل المثال:<syntaxhighlight lang="javascript">
 +
const server = net.createServer((socket) => {
 +
  socket.end('goodbye\n');
 +
}).on('error', (err) => {
 +
  // معالجة الأخطاء هنا
 +
  throw err;
 +
});
  
لا يجب استدعاء server.address()‎ حتى ينطلق الحدث 'listening'.
+
// انتزاع منفذ غير مستخدم عشوائيًا.
 
+
server.listen(() => {
=== <code>server.close([callback])‎</code> ===
+
  console.log('opened server on', server.address());
 +
});
 +
</syntaxhighlight>لا يجب استدعاء <code>server.address()‎</code> حتى ينطلق الحدث <code>'listening'</code>.
 +
===<code>server.close([callback])‎</code>===
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 +
* <code>callback‏</code> [[JavaScript/Function|<Function>]]: الدالة التي ستستدعى عند إغلاق الاتصال مع الخادم.
  
القيمة المُعادة: من النوع <net.Server>.
+
* القيمة المُعادة: من النوع <code><net.Server></code>.
 
+
يمنع الخادم من قبول اتصالات جديدة ويحافظ على الاتصالات الموجودة. وهو دالة غير متزامنة، ويُغلَق الخادم أخيراً عند إنهاء كافة الاتصالات ويُطلِق الخادم حدث <code>'close'</code>. وتُستدعى دالة رد الاتصال <code>callback</code> الاختيارية بمجرد حدوث الحدث <code>'close'</code>. على عكس هذا الحدث ستستدعى مع <code>Error</code> كوسيط وحيد إذا كان الخادم غير مفتوح عند إغلاقه.
يمنع الخادم من قبول اتصالات جديدة ويحافظ على الاتصالات الموجودة. وهو دالة غير متزامنة، ويُغلَق الخادم أخيراً عند إنهاء كافة الاتصالات ويُطلِق الخادم حدث 'close'. وتُستدعى دالة رد الاتصال callback الاختيارية بمجرد حدوث الحدث 'close'. على عكس هذا الحدث ستستدعى مع Error كوسيط وحيد إذا كان الخادم غير مفتوح عند إغلاقه.
+
===<code>server.connections</code> (مُهمَل)===
 
+
أُضيف مع الإصدار: v0.2.0، وأُهمِل مع الإصدار: v0.9.7.
=== <code>server.connections</code> (مُهمَل) ===
 
أُضيف مع الإصدار: v0.2.0، وأُهمِلت مع الإصدار: v0.9.7.
 
  
مؤشر الاستقرار: 0 -- مُهمل: يُستخدم server.getConnections()‎ بدلاً منه.
+
مؤشر الاستقرار: 0 - مُهمل: يُستخدم <code>server.getConnections()‎</code> بدلاً منه.
  
 
عدد الاتصالات المتزامنة مع الخادم.
 
عدد الاتصالات المتزامنة مع الخادم.
  
ويصبح null عند إرسال مقبس لأحد الأبناء بواسطة التابع child_process.fork()‎. لاستطلاع التفرعات والحصول على العدد الحالي من الاتصالات النشطة يستخدم التابع server.getConnections()‎ غير المتزامن بدلاً من ذلك.
+
ويصبح <code>null</code> عند إرسال مقبس لأحد الأبناء بواسطة التابع <code>[[Node.js/child process|child_process.fork()]]</code>‎. لاستطلاع التفرعات والحصول على العدد الحالي من الاتصالات النشطة يستخدم التابع <code>server.getConnections()‎</code> غير المتزامن بدلاً من ذلك.
 
+
===<code>server.getConnections(callback)‎</code>===
=== <code>server.getConnections(callback)‎</code> ===
 
 
أُضيف مع الإصدار: v0.9.7.
 
أُضيف مع الإصدار: v0.9.7.
 +
* <code>callback‏</code> [[JavaScript/Function|<Function>]].
  
القيمة المُعادة: من النوع <net.Server>.
+
* القيمة المُعادة: من النوع <code><net.Server></code>.
 
 
 
يعيد بشكل غير متزامن عدد الاتصالات المتزامنة مع الخادم. يعمل عند إرسال مقبس التوصيل إلى التفريعات.
 
يعيد بشكل غير متزامن عدد الاتصالات المتزامنة مع الخادم. يعمل عند إرسال مقبس التوصيل إلى التفريعات.
  
يجب تمرير وسيطين لدالة رد الاتصال err و count.
+
يجب تمرير وسيطين لدالة رد الاتصال <code>err</code> و <code>count</code>.
 
+
===<code>server.listen()‎</code>===
=== <code>server.listen()‎</code> ===
+
بدء تشغيل خادم يستمع للاتصالات. يمكن أن يكون <code>net.Server</code> خادم TCP أو IPC اعتمادًا على ما يستمع إليه.
بدء تشغيل خادم يستمع للاتصالات. يمكن أن يكون net.Server خادم TCP أو IPC اعتماداً على ما يستمع إليه.
 
  
 
الأشكال الممكنة:
 
الأشكال الممكنة:
 +
* <code>server.listen(handle[, backlog][, callback])‎</code>
 +
* <code>server.listen(options[, callback])‎</code>
 +
* <code>server.listen(path[, backlog][, callback])‎</code> لخوادم IPC.
 +
* <code>server.listen([port[, host[, backlog]]][, callback])‎</code> لخوادم TCP.
 +
هذه الدالة غير متزامنة. عند بدء الخادم في الاستماع، يُطلق حدث <code>'listening'</code>. وسيضاف المعامل الأخير <code>callback</code> كمستمع للحدث <code>'listening'</code>.
  
<code>server.listen(handle[, backlog][, callback])</code>
+
يمكن أن تأخذ جميع توابع <code>listen()</code>‎‎ معامل تراكم <code>backlog</code> لتعيين الحد الأقصى لطول قائمة الانتظار للاتصالات المعلقة. وستُحدد المدة الفعلية من قِبل نظام التشغيل من خلال إعدادات sysctl مثل <code>tcp_max_syn_backlog</code> و <code>somaxconn</code> في Linux. وتكون القيمة الافتراضية لهذا المعامل 511 (وليس 512).
 
 
<code>server.listen(options[, callback])‎</code>
 
 
 
<code>server.listen(path[, backlog][, callback])‎</code> لخوادم IPC.
 
 
 
<code>server.listen([port[, host[, backlog]]][, callback])‎</code> لخوادم TCP.
 
 
 
هذه الدالة غير متزامنة. عند بدء الخادم في الاستماع، يُطلق حدث 'listening'. وسيضاف المعامل الأخير callback كمستمع للحدث 'listening'.
 
 
 
يمكن أن تأخذ جميع توابع listen()‎‎ معامل تراكم backlog لتعيين الحد الأقصى لطول قائمة الانتظار للاتصالات المعلقة. وستُحدد المدة الفعلية من قِبل نظام التشغيل من خلال إعدادات sysctl مثل tcp_max_syn_backlog و somaxconn في Linux. وتكون القيمة الافتراضية لهذا المعامل 511 (وليس 512).
 
 
 
وتُضبط جميع net.Socket على SO_REUSEADDR (انظر socket(7) لمزيد من التفاصيل).
 
  
يمكن استدعاء التابع server.listen()‎ مرة أخرى إذا وفقط إذا كان هناك خطأ أثناء استدعاء server.listen()‎ الأول أو استدعاء server.close()‎. خلاف ذلك، سيُطلق خطأ ERR_SERVER_ALREADY_LISTEN.
+
وتُضبط جميع <code>net.Socket</code> على <code>SO_REUSEADDR</code> (انظر <code>[http://man7.org/linux/man-pages/man7/socket.7.html socket(7)‎]</code> لمزيد من التفاصيل).
  
أحد الأخطاء الأكثر شيوعاً التي أثيرت عند الاستماع هو EADDRINUSE. ويحدث هذا عند استماع خادم آخر على المنفذ والمسار والمعالج المطلوبين. أحد طرق التعامل مع ذلك يكون بإعادة المحاولة بعد فترة معينة من الزمن:
+
يمكن استدعاء التابع <code>server.listen()‎</code> مرة أخرى إذا وفقط إذا كان هناك خطأ أثناء استدعاء <code>server.listen()‎</code> الأول أو استدعاء <code>server.close()‎</code>. خلاف ذلك، سيُطلق خطأ <code>ERR_SERVER_ALREADY_LISTEN</code>.
  
==== <code>server.listen(handle[, backlog][, callback])</code> ====
+
أحد الأخطاء الأكثر شيوعاً التي أثيرت عند الاستماع هو <code>EADDRINUSE</code>. ويحدث هذا عند استماع خادم آخر على <code>port</code>/<code>path</code>/<code>handle</code> المطلوبين. أحد طرق التعامل مع ذلك يكون بإعادة المحاولة بعد فترة معينة من الزمن:<syntaxhighlight lang="javascript">
 +
server.on('error', (e) => {
 +
  if (e.code === 'EADDRINUSE') {
 +
    console.log('Address in use, retrying...');
 +
    setTimeout(() => {
 +
      server.close();
 +
      server.listen(PORT, HOST);
 +
    }, 1000);
 +
  }
 +
});
 +
</syntaxhighlight>
 +
===<code>server.listen(handle[, backlog][, callback])</code>===
 
أُضيف مع الإصدار: v0.5.10.
 
أُضيف مع الإصدار: v0.5.10.
 +
* <code>handle</code> من النوع <code>[[JavaScript/Object|<Object>]]</code>.
 +
* <code>backlog</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهو معامل شائع لدوال <code>server.listen()</code>‎.
 +
* <code>callback</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع لدوال <code>server.listen()</code>‎.
  
handle من النوع <Object>.
+
* القيمة المُعادة: من النوع <code><net.Server></code>.
 
+
بدء تشغيل خادم للاستماع للاتصالات على <code>handle</code> سبق ربطه مع منفذ، أو مقبس نطاق UNIX، أو أنبوب ويندوز المسمى.
backlog من النوع <number>: وهو معامل شائع لدوال server.listen()‎.
 
 
 
callback من النوع <Function>: وهو معامل شائع لدوال server.listen()‎.
 
 
 
القيمة المُعادة: من النوع <net.Server>.
 
 
 
بدء تشغيل خادم للاستماع للاتصالات على handle سبق ربطه مع منفذ، أو مقبس نطاق UNIX، أو أنبوب Windows المسمى.
 
 
 
يمكن أن يكون الكائن handle أما خادم أو مقبس (أي شيء مع عضو ‎_handle أساسي) أو كائن مع عضو fd يكون واصف ملف صالح.
 
  
ولا يدعم Windows الاستماع إلى واصف ملف.
+
يمكن أن يكون الكائن handle أما خادم أو مقبس (أي شيء مع عضو <code>‎_handle</code> أساسي) أو كائن مع عضو <code>fd</code> يكون واصف ملف صالح.
  
==== <code>server.listen(options[, callback])</code> ====
+
ولا يدعم ويندوز الاستماع إلى واصف ملف.
 +
===<code>server.listen(options[, callback])</code>===
 
أُضيفت مع الإصدار: 0.11.14.
 
أُضيفت مع الإصدار: 0.11.14.
 +
* <code>options</code> من النوع <code>[[JavaScript/Object|<Object>]]</code>: ويجب إدخاله. وهو يدعم الخصائص التالية:
 +
** <code>port</code> من النوع <code>[[JavaScript/Number|<number>]]</code>.
 +
** <code>host</code> من النوع <code>[[JavaScript/String|<string>]]</code>.
 +
** <code>path</code> من النوع <code>[[JavaScript/String|<string>]]</code>: سيُتجاهل إذا حُدِد port. راجع تحديد مسارات اتصالات IPC.
 +
** <code>backlog</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهو معامل شائع لدوال <code>server.listen()</code>‎.
 +
** <code>exclusive</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>. وتكون القيمة الافتراضية: <code>false</code>.
 +
** <code>readableAll</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وهو يجعل الأنابيب مقروءة لجميع المستخدمين في خوادم IPC. وتكون القيمة الافتراضية: false.
 +
** <code>writableAll</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وهو يجعل الأنابيب قابلة للكتابة لجميع المستخدمين في خوادم IPC. وتكون القيمة الافتراضية: <code>false</code>.
 +
* <code>callback</code> من النوع <code>[[JavaScript/Function|<Function>]]</code> وهو معامل شائع لدوال <code>server.listen()‎</code>.
 +
* القيمة المُعادة: من النوع <code><net.Server></code>.
 +
إذا حُدد <code>port</code>، فإنه يتصرف بنفس أسلوب <code>server.listen([port[, host[, backlog]]][, callback])</code>‎. وبخلاف ذلك، إذا حُدد <code>path</code>، فإنه يتصرف بنفس أسلوب <code>server.listen(path[, backlog][, callback])‎</code>. وإذا لم يحدد أي منهما، سيُطلَق خطأ.
  
options من النوع <Object>: ويجب إدخاله. وهو يدعم الخصائص التالية:
+
إذا كانت قيمة <code>exclusive</code> هي <code>false</code> (افتراضيًا)، ستستخدم مشغلات العنقود نفس المعالج الأساسي، سامحًا بمشاركة مهام معالجة الاتصال. أما إذا كانت قيمة <code>exclusive</code> هي <code>true</code>، فلا تُشارَك المُعالج، وتؤدي محاولة مشاركة المنفذ إلى خطأ. فيما يلي مثال على الاستماع إلى منفذ حصري:<syntaxhighlight lang="javascript">
 
+
server.listen({
port من النوع <number>.
+
  host: 'localhost',
 
+
  port: 80,
host من النوع <string>.
+
  exclusive: true
 
+
});
path من النوع <string>: سيُتجاهل إذا حُدِد port. راجع تحديد مسارات اتصالات IPC.
+
</syntaxhighlight>قد يتسبب بدء تشغيل خادم IPC كجذر في أن يكون مسار الخادم غير قابل للوصول للمستخدمين غير المتمتعين بامتيازات. سيؤدي استخدام <code>readableAll</code> و <code>writableAll</code> إلى أن يكون الخادم في متناول جميع المستخدمين.
 
+
===<code>server.listen(path[, backlog][, callback])</code>===
backlog من النوع <number>: وهو معامل شائع لدوال server.listen()‎.
 
 
 
exclusive من النوع <boolean>. وتكون القيمة الافتراضية: false.
 
 
 
readableAll من النوع <boolean>: وهو يجعل الأنابيب مقروءة لجميع المستخدمين في خوادم IPC. وتكون القيمة الافتراضية: false.
 
 
 
writableAll من النوع <boolean>: وهو يجعل الأنابيب قابلة للكتابة لجميع المستخدمين في خوادم IPC. وتكون القيمة الافتراضية: false.
 
 
 
callback من النوع <Function>: وهو معامل شائع لدوال server.listen()‎.
 
 
 
القيمة المُعادة: من النوع <net.Server>.
 
 
 
إذا حُدد port، فإنه يتصرف بنفس أسلوب server.listen([port[, host[, backlog]]][, callback]). وبخلاف ذلك، إذا حُدد path، فإنه يتصرف بنفس أسلوب server.listen(path[, backlog][, callback]). وإذا لم يحدد أي منهما، سيُطلَق خطأ.
 
 
 
إذا كانت قيمة exclusive هي false (افتراضيًا)، ستستخدم مشغلات العنقود نفس المعالج الأساسي، سامحًا بمشاركة مهام معالجة الاتصال. أما إذا كانت قيمة exclusive هي true، فلا تُشارَك المُعالج، وتؤدي محاولة مشاركة المنفذ إلى خطأ. فيما يلي مثال على الاستماع إلى منفذ حصري exclusive.
 
 
 
قد يتسبب بدء تشغيل خادم IPC كجذر في أن يكون مسار الخادم غير قابل للوصول للمستخدمين غير المتمتعين بامتيازات. سيؤدي استخدام readableAll و writableAll إلى أن يكون الخادم في متناول جميع المستخدمين.
 
 
 
==== <code>server.listen(path[, backlog][, callback])</code> ====
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>path</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهو المسار الذي يجب على الخادم الاستماع إليه. راجع تحديد مسارات اتصالات IPC.
path من النوع <string>: وهو المسار الذي يجب على الخادم الاستماع إليه. راجع تحديد مسارات اتصالات IPC.
+
* <code>backlog</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهو معامل شائع لدوال <code>server.listen()</code>‎.
 
+
* <code>callback</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع لدوال <code>server.listen()</code>‎.
backlog من النوع <number>: وهو معامل شائع لدوال server.listen()‎.
+
* القيمة المُعادة: من النوع <code><net.Server></code>.
 
+
بدء تشغيل خادم IPC للاستماع للاتصالات على <code>path</code> معين.
callback من النوع <Function>: وهو معامل شائع لدوال server.listen()‎.
+
===<code>server.listen([port[, host[, backlog]]][, callback])</code>===
 
 
القيمة المُعادة: من النوع <net.Server>.
 
 
 
بدء تشغيل خادم IPC للاستماع للاتصالات على path معين.
 
 
 
==== <code>server.listen([port[, host[, backlog]]][, callback])</code> ====
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 +
* <code>port</code> من النوع <code>[[JavaScript/Number|<number>]]</code>.
 +
* <code>host</code> من النوع <code>[[JavaScript/String|<string>]]</code>.
 +
* <code>backlog</code> من النوع <code>[[JavaScript/Number|<number>]]</code> وهو معامل شائع لدوال <code>server.listen()</code>‎.
 +
* <code>callback</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع لدوال <code>server.listen()</code>‎.
 +
* القيمة المُعادة: من النوع <code><net.Server></code>.
 +
بدء تشغيل خادم TCP للاستماع للاتصالات على <code>port</code> و <code>host</code> معينين.
  
port من النوع <number>.
+
إذا حُذف المنفذ <code>port</code> أو كان <code>0</code>، سيُعين نظام التشغيل منفذ عشوائي غير مستخدم، والذي يمكن استعادته باستخدام <code>server.address()‎‎.port</code> بعد إطلاق الحدث <code>'listening'</code>.
 
 
host من النوع <string>.
 
 
 
backlog من النوع <number>: وهو معامل شائع لدوال server.listen().
 
 
 
callback من النوع <Function>: وهو معامل شائع لدوال server.listen()‎.
 
 
 
القيمة المُعادة: من النوع <net.Server>.
 
 
 
بدء تشغيل خادم TCP للاستماع للاتصالات على port و host معينين.
 
  
إذا حُذف المنفذ port أو كان 0، سيُعين نظام التشغيل منفذ عشوائي غير مستخدم، والذي يمكن استعادته باستخدام server.address()‎‎.port بعد إطلاق الحدث 'listening'.
+
إذا حُذف المضيف host، سيقبل الخادم الاتصالات على [[wikipedia:IPv6_address#Unspecified_address|عنوان IPv6 غير محدد]] (<code>::</code>) عندما يتوفر IPv6، أو [[wikipedia:0.0.0.0|عنوان IPv4 غير محدد]] (<code>0.0.0.0</code>) خلاف ذلك.
  
إذا حُذف المضيف host، سيقبل الخادم الاتصالات على عنوان IPv6 غير محدد (::) عندما يتوفر IPv6، أو عنوان IPv4 غير محدد (0.0.0.0) خلاف ذلك.
+
في معظم أنظمة التشغيل قد يتسبب الاستماع إلى [[wikipedia:IPv6_address#Unspecified_address|عنوان IPv6 غير محدد]] (<code>::</code>) في استماع <code>net.Server</code> أيضا إلى [[wikipedia:0.0.0.0|عنوان IPv4 غير محدد]]  (<code>0.0.0.0</code>).
 
+
===<code>server.listening</code>===
في معظم أنظمة التشغيل قد يتسبب الاستماع إلى عنوان IPv6 (::) غير محدد في استماع net.Server أيضا إلى عنوان IPv4 (0.0.0.0) غير محدد.
 
 
 
=== <code>server.listening</code> ===
 
 
أُضيفت مع الإصدار: v5.7.0.
 
أُضيفت مع الإصدار: v5.7.0.
 +
* من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وهو يشير إلى ما إذا كان الخادم يستمع للاتصالات أم لا.
  
من النوع <boolean>: وهو يشير إلى ما إذا كان الخادم يستمع للاتصالات أم لا.
+
===<code>server.maxConnections</code>===
 
+
أضيفت مع الإصدار: v0.2.0.
=== <code>server.maxConnections</code> ===
 
أضيفت مع الإصدار: v0.2.0
 
  
 
تُضبط هذه الخاصية لرفض الاتصالات عندما يكون عدد الاتصالات بالخادم كبيرًا.
 
تُضبط هذه الخاصية لرفض الاتصالات عندما يكون عدد الاتصالات بالخادم كبيرًا.
  
من غير المستحسن استخدام هذا الخيار عند إرسال مقبس إلى أحد الأبناء خلال child_process.fork()‎.
+
من غير المستحسن استخدام هذا الخيار عند إرسال مقبس إلى أحد الأبناء خلال <code>[[Node.js/child process|child_process.fork()‎]]</code>.
 
+
===<code>server.ref()‎</code>===
=== <code>server.ref()‎</code> ===
 
 
أُضيف مع الإصدار: v0.9.1.
 
أُضيف مع الإصدار: v0.9.1.
 
+
* القيمة المُعادة: من النوع <code><net.Server></code>.
القيمة المُعادة: من النوع <net.Server>.
+
على عكس <code>unref()‎</code>، استدعاء <code>ref()</code>‎ على خادم سبق إجراء <code>unref</code> عليه لن يسمح للبرنامج بالانتهاء إذا كان هو الخادم الوحيد المتبقي (السلوك الافتراضي). أما استدعاء <code>ref()</code>‎ مرة أخرى على خادم سبق إجراء <code>ref</code> عليه فلن يكون له أي تأثير.
 
+
===<code>server.unref()‎</code>===
على عكس unref()‎، استدعاء ref()‎ على خادم سبق إجراء unref عليه لن يسمح للبرنامج بالانتهاء إذا كان هو الخادم الوحيد المتبقي (السلوك الافتراضي). أما استدعاء ref()‎ مرة أخرى على خادم سبق إجراء ref عليه فلن يكون له أي تأثير.
 
 
 
=== <code>server.unref()‎</code> ===
 
 
أُضيف مع الإصدار: v0.9.1.
 
أُضيف مع الإصدار: v0.9.1.
 
+
* القيمة المُعادة: من النوع <code><net.Server></code>.
القيمة المُعادة: من النوع <net.Server>.
+
يسمح استدعاء <code>unref()</code>‎ على خادم للبرنامج بالإنهاء إذا كان هو الخادم النشط الوحيد في نظام الأحداث. أما  استدعاء <code>unref()‎</code> مرة أخرى على خادم سبق إجراء <code>unref</code> عليه فلن يكون له أي تأثير.
 
+
==الصنف <code>net.Socket</code>==
يسمح استدعاء unref()‎ على خادم للبرنامج بالإنهاء إذا كان هو الخادم النشط الوحيد في نظام الأحداث. أما  استدعاء unref()‎ مرة أخرى على خادم سبق إجراء unref عليه فلن يكون له أي تأثير.
 
 
 
== الصنف: <code>net.Socket</code> ==
 
 
أُضيف مع الإصدار: v0.3.4.
 
أُضيف مع الإصدار: v0.3.4.
  
يعد هذا الصنف تجريد لمقبس TCP أو لنقطة نهاية دفق IPC (يستخدم الأنابيب المسماة في Windows، ومقابس مجال UNIX خلاف ذلك). وتعد net.Socket أيضا تيارًا مزدوجًا، حيث يمكن أن تكون قابلة للقراءة والكتابة على حد سواء، وهي أيضا EventEmitter.
+
يعد هذا الصنف تجريد لمقبس TCP أو لنقطة نهاية دفق IPC (يستخدم الأنابيب المسماة في ويندوز، ومقابس مجال UNIX خلاف ذلك). وتعد <code>net.Socket</code> أيضا [[Node.js/stream|تيارًا مزدوجًا (duplex stream)]]، حيث يمكن أن تكون قابلة للقراءة والكتابة على حد سواء، وهي أيضا <code>[[Node.js/events|EventEmitter]]</code>.
 
 
ويمكن للمستخدم إنشاء net.Socket واستخدامها مباشرة في التفاعل مع الخادم. على سبيل المثال، تُعاد من قِبل net.createConnection()‎، بحيث يمكن للمستخدم استخدامها للتحدث إلى الخادم.
 
  
ويمكن أيضا إنشاؤها بواسطة Node.js وتمريرها إلى المستخدم عند تلقي اتصال. على سبيل المثال، يتم تُمرر إلى مستمعي الحدث 'connection' المُصدر على net.Server بحيث يمكن للمستخدم استخدامها للتفاعل مع العميل.
+
ويمكن للمستخدم إنشاء <code>net.Socket</code> واستخدامها مباشرة في التفاعل مع الخادم. على سبيل المثال، تُعاد من قِبل <code>net.createConnection()‎</code>، بحيث يمكن للمستخدم استخدامها للتحدث إلى الخادم.
  
=== <code>new net.Socket([options])‎</code> ===
+
ويمكن أيضا إنشاؤها بواسطة Node.js وتمريرها إلى المستخدم عند تلقي اتصال. على سبيل المثال، تُمرر إلى مستمعي الحدث <code>'connection'</code> المُصدر على <code>net.Server</code> بحيث يمكن للمستخدم استخدامها للتفاعل مع العميل.
 +
===<code>new net.Socket([options])‎</code>===
 
أُضيف مع الإصدار: v0.3.4.
 
أُضيف مع الإصدار: v0.3.4.
  
 
إنشاء كائن مقبس جديد.
 
إنشاء كائن مقبس جديد.
 
+
* <code>options</code> من النوع <code>[[JavaScript/Object|<Object>]]</code>: .الخيارات المتاحة هي:
options من النوع <Object>: .الخيارات المتاحة هي:
+
** <code>fd</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهو يغلف حول مقبس موجود مع واصف ملف معين، خلاف ذلك سيُنشَأ مقبس جديد.
 
+
** <code>allowHalfOpen</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وهو يشير إلى ما إذا كان مسموح باتصالات TCP مفتوحة نصفيا. راجع <code>net.createServer()‎‎</code> والحدث <code>'end'</code> لمزيد من التفاصيل. القيمة الافتراضية: <code>false</code>.
fd من النوع <number>: وهو يغلف حول مقبس موجود مع واصف ملف معين، خلاف ذلك سيُنشَأ مقبس جديد.
+
** <code>readable</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وهو يسمح بالقراءة على المقبس عند تمرير <code>fd</code>، ويُتجاهل بخلاف ذلك. القيمة الافتراضية: <code>false</code>.
 
+
** <code>writable</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: ويسمح بالكتابة على المقبس عند تمرير <code>fd</code>، ويُتجاهل بخلاف ذلك. القيمة الافتراضية: <code>false</code>.
allowHalfOpen من النوع <boolean>: وهو يشير إلى ما إذا كان مسموح باتصالات TCP مفتوحة نصفيا. راجع net.createServer()‎‎ والحدث 'end' لمزيد من التفاصيل. القيمة الافتراضية: false.
+
* القيمة المُعادة: من النوع <code><net.Socket></code>.
 
+
يمكن أن يكون مأخذ التوصيل المُنشأ حديثا أما مقبس توصيل TCP أو نقطة نهاية IPC، اعتماداً على ما تتصل به من خلال <code>connect()</code>‎‎.
readable من النوع <boolean>: وهو يسمح بالقراءة على المقبس عند تمرير fd ، ويُتجاهل بخلاف ذلك. القيمة الافتراضية: false.
+
===الحدث <code>'close'</code>===
 
 
writable من النوع <boolean>: ويسمح بالكتابة على المقبس عند تمرير fd، ويُتجاهل بخلاف ذلك. القيمة الافتراضية: false.
 
 
 
القيمة المُعادة: من النوع <net.Socket>.
 
 
 
يمكن أن يكون مأخذ التوصيل المُنشأ حديثا أما مقبس توصيل TCP أو نقطة نهاية IPC، اعتماداً على ما تتصل به من خلال connect()‎‎.
 
 
 
=== الحدث: 'close' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>hadError</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وتكون قيمتها <code>true</code> إذا حدث للمقبس خطأ في النقل.
hadError من النوع <boolean>: وتكون قيمتها true إذا حدث للمقبس خطأ في النقل.
+
يُطلٓق حالما يغلق المقبس بالكامل. ويشير الوسيط <code>hadError</code> وهو قيمة منطقية إذا كان المقبس مغلقا بسبب خطأ في النقل.
 
+
===الحدث <code>'connect'</code>===
يُطلٓق حالما يغلق المقبس بالكامل. ويشير الوسيط hadError وهو قيمة منطقية إذا كان المقبس مغلقا بسبب خطأ في النقل.
 
 
 
=== الحدث: 'connect' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
 
يطلق عند إتمام اتصال المقبس بنجاح. راجع <code>net.createConnection()‎</code>.
 
يطلق عند إتمام اتصال المقبس بنجاح. راجع <code>net.createConnection()‎</code>.
 
+
===الحدث <code>'data'</code>===
=== الحدث: 'data' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 +
* من النوع ‎‎[[Node.js/buffer|<code><Buffer></code>]]|<code>[[JavaScript/String|<string>‎]]</code>
 +
يُطلق عند استلام البيانات. وسيكون الوسيط <code>data</code> من النوع <code>Buffer</code> أو <code>String</code>. ويُضبط ترميز البيانات بواسطة <code>socket.setEncoding()‎</code>.
  
من النوع <Buffer>:|<string>:
+
علما بأن <code>data</code> ستُفقَد إذا لم يكن هناك أي مستمع عندما يُطلِق <code>Socket</code> الحدث <code>'data'</code>.
 
+
===الحدث <code>'drain'</code>===
يُطلق عند استلام البيانات. وسيكون الوسيط data من النوع Buffer أو String. ويُضبط ترميز البيانات بواسطة socket.setEncoding()‎.
 
 
 
علما بأن data ستفقد إذا لم يكن هناك أي مستمع عندما يُطلِق Socket الحدث 'data'.
 
 
 
=== الحدث: 'drain' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
 
يُطلق عندما يصبح مخزن الكتابة المؤقت فارغا. يمكن أن يستخدم لخنق التحميلات.
 
يُطلق عندما يصبح مخزن الكتابة المؤقت فارغا. يمكن أن يستخدم لخنق التحميلات.
  
انظر أيضا: القيم المعادة من socket.write()‎.
+
انظر أيضًا: القيم المعادة من <code>socket.write()</code>‎.
 
+
===الحدث <code>'end'</code>===
=== الحدث: 'end' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
 
يطلق عندما يرسل الطرف الآخر من المقبس حزمة FIN، منهيًا بذلك الجانب المقروء من المقبس.
 
يطلق عندما يرسل الطرف الآخر من المقبس حزمة FIN، منهيًا بذلك الجانب المقروء من المقبس.
  
افتراضيًا (allowHalfOpen قيمتها false) سيرسل المقبس حزمة FIN مرة أخرى ويهدم واصف الملف تو كتابته أثناء وجوده في قائمة انتظار الكتابة. ومع ذلك، إذا ضُبطت allowHalfOpen بالقيمة true، لن ينهي المقبس تلقائيا جانب الكتابة الخاص به بواسطة التابعend()‎، مما يتيح للمستخدم كتابة كميات عشوائية من البيانات. يجب على المستخدم استدعاء end()‎ صراحةً لإغلاق الاتصال (أي إرسال حزمة FIN مرة أخرى).
+
افتراضيًا (<code>allowHalfOpen</code> قيمتها <code>false</code>) سيرسل المقبس حزمة FIN مرة أخرى ويهدم واصف الملف تو كتابته أثناء وجوده في قائمة انتظار الكتابة. ومع ذلك، إذا ضُبطت <code>allowHalfOpen</code> بالقيمة <code>true</code>، لن ينهي المقبس تلقائيا جانب الكتابة الخاص به بواسطة التابع<code>end()</code>‎، مما يتيح للمستخدم كتابة كميات عشوائية من البيانات. يجب على المستخدم استدعاء <code>end()</code>‎ صراحةً لإغلاق الاتصال (أي إرسال حزمة FIN مرة أخرى).
 
+
===الحدث <code>'error'</code>===
=== الحدث: 'error' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* من النوع <code>[[JavaScript/Error|<Error>]]</code>.
من النوع <Error>.
 
 
 
 
يُطلَق عند حدوث خطأ ما. سيُستدعى الحدث 'close' مباشرة بعد هذا الحدث.
 
يُطلَق عند حدوث خطأ ما. سيُستدعى الحدث 'close' مباشرة بعد هذا الحدث.
 
+
===الحدث <code>'lookup'</code>===
=== الحدث: 'lookup' ===
+
سجل التغييرات
 +
{| class="wikitable"
 +
!الإصدار
 +
!التغييرات
 +
|-
 +
|v5.10.0
 +
|أصبح المعامل <code>host</code> مدعومًا الآن.
 +
|-
 +
|v0.11.3
 +
|أضيف مع الإصدار: v0.11.3.
 +
|}
 
يُطلَق بعد حل اسم المضيف ولكن قبل الاتصال. لا ينطبق على مقابس UNIX.
 
يُطلَق بعد حل اسم المضيف ولكن قبل الاتصال. لا ينطبق على مقابس UNIX.
 +
* <code>err</code> من النوع ‎<code>[[JavaScript/Error|<Error>]]</code> | <code>[[JavaScript/null|<null>]]</code>‎ وهو كائن الخطأ. انظر <code>[[Node.js/dns|dns.lookup()]]</code>‎.
 +
* <code>address</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهو عنوان IP.
 +
* <code>family</code> من النوع ‎<code>[[JavaScript/String|<string>]]</code> | <code>[[JavaScript/null|<null>]]</code>‎ وهو نوع العنوان. انظر <code>[[Node.js/dns|dns.lookup()]]</code>‎‎.
 +
* <code>host</code> من النوع <code>[[JavaScript/String|<string>]]</code>: اسم المضيف.
  
err من النوع <Error>: | <null>: وهو كائن الخطأ. انظر dns.lookup()‎.
+
===الحدث <code>'ready'</code>===
 
 
address من النوع <string>: وهو عنوان IP.
 
 
 
family من النوع <string>: | <null>: وهو نوع العنوان. انظر dns.lookup()‎.
 
 
 
host من النوع <string>: اسم المضيف.
 
 
 
=== الحدث: 'ready' ===
 
 
أُضيف مع الإصدار: v9.11.0.
 
أُضيف مع الإصدار: v9.11.0.
  
 
يُطلَق عندما يكون مقبس ما على استعداد لاستخدامه.
 
يُطلَق عندما يكون مقبس ما على استعداد لاستخدامه.
  
ويُطلَق فورًا بعد الحدث 'connect'.
+
ويُطلَق فورًا بعد الحدث <code>'connect'</code>.
 
+
===الحدث <code>'timeout'</code>===
=== الحدث: 'timeout' ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
 
يُطلَق إذا انتهت مهلة المقبس نتيجة الخمول. و الغرض منه أن يخطر فقط أن المقبس خامل. يجب على المستخدم إغلاق الاتصال يدويًا.
 
يُطلَق إذا انتهت مهلة المقبس نتيجة الخمول. و الغرض منه أن يخطر فقط أن المقبس خامل. يجب على المستخدم إغلاق الاتصال يدويًا.
  
انظر أيضا: socket.setTimeout()‎.
+
انظر أيضًا: <code>socket.setTimeout()‎</code>.
 
+
===<code>socket.address()‎</code>===
=== <code>socket.address()‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* القيمة المُعادة: من النوع <code>[[JavaScript/Object|<Object>]]</code>.
القيمة المُعادة: من النوع <Object>.
+
يعيد العنوان <code>address</code> المنضم واسم عائلة العنوان <code>family</code> ومنفذ الخادم <code>port</code> كما يذكره نظام التشغيل. <code>{ port: 12346, family: 'IPv4', address: '127.0.0.1' }</code>
 
+
===<code>socket.bufferSize</code>===
يعيد العنوان address المنضم واسم أسرة العنوان family ومنفذ الخادم port كما يذكره نظام التشغيل. { port: 12346, family: 'IPv4', address: '127.0.0.1' }
 
 
 
=== <code>socket.bufferSize</code> ===
 
 
أُضيفت مع الإصدار: v0.3.8.
 
أُضيفت مع الإصدار: v0.3.8.
  
من خواصnet.Socket أن التابع socket.write()‎ دائما ما يعمل. وهذا لمساعدة المستخدمين للبدء والانطلاق بسرعة. لا يمكن لجهاز الكمبيوتر مواكبة كمية البيانات المكتوبة على المقبس دائماً، فقد يؤدي ببساطة إلى بطء شديد بشبكة الاتصال. وستصُف Node.js البيانات المكتوبة إلى المقبس داخليًا وترسلها عبر الأسلاك عندما يكون ذلك ممكناً. (فهي تختار واصف ملف المقبس داخليا لكونه قابل للكتابة).
+
من خواص <code>net.Socket</code> أن التابع <code>socket.write()‎</code> دائما ما يعمل. وهذا لمساعدة المستخدمين للبدء والانطلاق بسرعة. لا يمكن لجهاز الكمبيوتر مواكبة كمية البيانات المكتوبة على المقبس دائماً، فقد يؤدي ببساطة إلى بطء شديد بشبكة الاتصال. وستصُف Node.js البيانات المكتوبة إلى المقبس داخليًا وترسلها عبر الأسلاك عندما يكون ذلك ممكناً. (فهي تختار واصف ملف المقبس داخليا لكونه قابل للكتابة).
  
 
وقد تتزايد الذاكرة نتيجة لهذا التخزين الداخلي المؤقت. وتبين هذه الخاصية عدد الأحرف المخزنة حاليا بغرض كتابتها. (عدد الأحرف مساو تقريبا للعدد البايتات المراد كتابتها، ولكن قد يحتوي المخزن المؤقت على سلاسل، والتي ترمَّز ببطء، لذلك لا يمكن معرفة عدد البايتات بالضبط).
 
وقد تتزايد الذاكرة نتيجة لهذا التخزين الداخلي المؤقت. وتبين هذه الخاصية عدد الأحرف المخزنة حاليا بغرض كتابتها. (عدد الأحرف مساو تقريبا للعدد البايتات المراد كتابتها، ولكن قد يحتوي المخزن المؤقت على سلاسل، والتي ترمَّز ببطء، لذلك لا يمكن معرفة عدد البايتات بالضبط).
  
يجب أن يحاول المستخدمون الذين يعانون من كِبر أو تزايد bufferSize "خنق" تدفق البيانات في برامجهم باستخدام socket.pause()‎ و socket.resume()‎.
+
يجب أن يحاول المستخدمون الذين يعانون من كِبر أو تزايد <code>bufferSize</code> "خنق" تدفق البيانات في برامجهم باستخدام <code>socket.pause()‎</code> و <code>socket.resume()‎</code>.
 
+
===<code>socket.bytesRead</code>===
=== <code>socket.bytesRead</code> ===
 
 
أضيفت مع الإصدار: v0.5.3.
 
أضيفت مع الإصدار: v0.5.3.
  
 
مقدار وحدات البايت المُتلقاة.
 
مقدار وحدات البايت المُتلقاة.
 
+
===<code>socket.bytesWritten</code>===
=== <code>socket.bytesWritten</code> ===
 
 
أضيفت مع الإصدار: v0.5.3.
 
أضيفت مع الإصدار: v0.5.3.
  
 
مقدار وحدات البايت المُرسَلة.
 
مقدار وحدات البايت المُرسَلة.
 
+
===<code>socket.connect()‎</code>===
=== <code>socket.connect()‎</code> ===
 
 
بدء اتصال مقبس معين.
 
بدء اتصال مقبس معين.
  
 
الأشكال الممكنة:
 
الأشكال الممكنة:
 
+
* <code>socket.connect(options[, connectListener])‎</code>
<code>socket.connect(options[, connectListener])‎</code>
+
* <code>socket.connect(path[, connectListener])‎</code> لاتصالات IPC.
 
+
* <code>socket.connect(port[, host][, connectListener])‎</code> لاتصالات TCP.
<code>socket.connect(path[, connectListener])‎</code> لاتصالات IPC.
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
 
+
هذه الدالة غير متزامنة. سيطلق الحدث <code>'connect'</code> عند تأسيس الاتصال. إذا كان هناك مشكلة في الاتصال سيُطلق الحدث <code>'error'</code> بدلا من الحدث <code>'connect'</code> ويُمرر مع الخطأ إلى مستمع <code>'error</code>'. سيضاف المعامل الأخير <code>connectListener</code>، إذا توفَّر، كمستمع للحدث <code>'connect'</code> مرة واحدة.
<code>socket.connect(port[, host][, connectListener])‎</code> لاتصالات TCP.
+
===<code>socket.connect(options[, connectListener])‎</code>===
 
+
سجل التغييرات
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
{| class="wikitable"
 
+
!الإصدار
هذه الدالة غير متزامنة. سيطلق الحدث 'connect' عند تأسيس الاتصال. إذا كان هناك مشكلة في الاتصال سيُطلق الحدث 'error' بدلا من الحدث 'connect' ويُمرر مع الخطأ إلى مستمع 'error'. سيضاف المعامل الأخير connectListener، إذا توفَّر، كمستمع للحدث 'connect' مرة واحدة.
+
!التغييرات
 
+
|-
==== <code>socket.connect(options[, connectListener])‎</code> ====
+
|v6.0.0
options من النوع  <Object>.
+
|أصبحت قيمة  الخيار <code>hints</code> الافتراضية <code>0</code> في كافة الحالات الآن. في السابق، كانت قيمته الافتراضية <code><nowiki>DNS.ADDRCONFIG | dns.V4MAPPED</nowiki></code>. في حالة عدم وجود خيار <code>family</code>.
 
+
|-
connectListener من النوع <Function>: وهو معامل شائع لتوابع socket.connect()‎. سيضاف كمستمع للحدث 'connect' مرة واحدة.
+
|v5.11.0
 
+
|أصبح الخيار  <code>hints</code>  مدعومًا الآن.
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
|-
 
+
|v0.1.90
بدء الاتصال على مقبس معين. لا يستخدم هذا التابع عادةً، وينبغي إنشاء المقبس و فتحه باستخدام net.createConnection()‎. وينصح باستخدامه فقط عند تنفيذ مقبس مخصص.
+
|أضيف مع الإصدار : v0.1.90.
 +
|}
 +
* <code>options</code> من النوع  <code>[[JavaScript/Object|<Object>]]</code>.
 +
* <code>connectListener</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع لتوابع <code>socket.connect()‎</code>. سيضاف كمستمع للحدث <code>'connect'</code> مرة واحدة.
 +
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
 +
بدء الاتصال على مقبس معين. لا يستخدم هذا التابع عادةً، وينبغي إنشاء المقبس و فتحه باستخدام <code>net.createConnection()‎</code>. وينصح باستخدامه فقط عند تنفيذ مقبس مخصص.
  
 
الخيارات المتاحة لاتصالات TCP هي:
 
الخيارات المتاحة لاتصالات TCP هي:
 
+
* <code>port</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهو قيمة يجب إدخالها. وهو المنفذ الذي يجب على المقبس الاتصال به.
port من النوع <number>: وهو قيمة يجب إدخالها. وهو المنفذ الذي يجب على المقبس الاتصال به.
+
* <code>host</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهو المضيف الذي يجب على المقبس الاتصال به. القيمة الافتراضية: <code>'localhost'</code>.
 
+
* <code>localAddress</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهو العنوان المحلي الذي يجب على المقبس الاتصال منه.
host من النوع <string>: وهو المضيف الذي يجب على المقبس الاتصال به. القيمة الافتراضية: 'localhost'.
+
* <code>localPort</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهو المنفذ محلي الذي يجب على المقبس الاتصال منه.
 
+
* <code>family</code> من النوع<code>[[JavaScript/Number|<number>]]</code>: نسخة من مُكدِّس IP، ويمكن أن تكون إما 4 أو 6. القيمة الافتراضية: 4.
localAddress من النوع <string>: وهو العنوان المحلي الذي يجب على المقبس الاتصال منه.
+
* <code>hints</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهي تلميحات اختيارية حول <code>dns.lookup()‎</code>.
 
+
* <code>lookup</code> من النوع <code>[[JavaScript/Function|<Function>]]</code> وهي دالة البحث المخصص. القيمة الافتراضية: <code>dns.lookup()‎</code>.
localPort من النوع <number>: وهو المنفذ محلي الذي يجب على المقبس الاتصال منه.
 
 
 
family من النوع <number>: نسخة من مُكدِّس IP، ويمكن أن تكون إما 4 أو 6. القيمة الافتراضية: 4.
 
 
 
hints من النوع <number>: وهي تلميحات اختيارية حول dns.lookup()‎.
 
 
 
lookup من النوع <Function>: وهي دالة البحث المخصص. القيمة الافتراضية: dns.lookup()‎.
 
 
 
 
الخيارات المتاحة لاتصالات IPC هي:
 
الخيارات المتاحة لاتصالات IPC هي:
 +
* <code>path</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهي قيمة يجب إدخالها. وهو المسار الذي يجب على العميل الاتصال به. راجع تحديد مسارات اتصالات IPC. وإذا توفرت، تُتَجاهَل خيارات TCP الخاصة المذكورة أعلاه.
  
path من النوع <string>: وهي قيمة يجب إدخالها. وهو المسار الذي يجب على العميل الاتصال به. راجع تحديد مسارات اتصالات IPC. وإذا توفرت، تُتَجاهَل خيارات TCP الخاصة المذكورة أعلاه.
+
===<code>socket.connect(path[, connectListener])‎</code>===
 
+
<code>path</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهو المسار الذي يجب على العميل الاتصال به. راجع تحديد مسارات اتصالات IPC.
==== <code>socket.connect(path[, connectListener])‎</code> ====
 
path من النوع <string>: وهو المسار الذي يجب على العميل الاتصال به. راجع تحديد مسارات اتصالات IPC.
 
 
 
connectListener من النوع <Function>: وهو معامل شائع لتوابع socket.connect()‎. سيضاف كمستمع للحدث 'connect' مرة واحدة.
 
 
 
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
 
  
 +
<code>connectListener</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع لتوابع <code>socket.connect()‎</code>. سيضاف كمستمع للحدث <code>'connect'</code> مرة واحدة.
 +
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
 
بدء اتصال IPC على المقبس المعطى.
 
بدء اتصال IPC على المقبس المعطى.
  
اسم مستعار يشير إلى socket.connect(options[, connectListener]) ويستدعى مع الخيار { path: path }.
+
اسم مستعار يشير إلى <code>socket.connect(options[, connectListener])</code>‎ ويستدعى مع الخيار <code>options</code> بالقيمة <code>{ path: path }</code>.
 
+
===<code>socket.connect(port[, host][, connectListener])‎</code>===
==== <code>socket.connect(port[, host][, connectListener])‎</code> ====
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>port</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهو المنفذ الذي يجب على العميل الاتصال به.
port من النوع <string>: وهو المنفذ الذي يجب على العميل الاتصال به.
+
* <code>host</code> من النوع <code>[[JavaScript/String|<string>]]</code>:  وهو المضيف الذي يجب على العميل الاتصال به.
 
+
* <code>connectListener</code> من النوع <code>[[JavaScript/Function|<Function>]]</code> وهو معامل شائع لتوابع <code>socket.connect()</code>‎. سيضاف كمستمع للحدث <code>'connect'</code> مرة واحدة.
host من النوع <string>:  وهو المضيف الذي يجب على العميل الاتصال به.
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
 
 
connectListener من النوع <Function>: وهو معامل شائع لتوابع socket.connect()‎. سيضاف كمستمع للحدث 'connect' مرة واحدة.
 
 
 
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
 
 
 
 
الشروع في اتصال TCP على المقبس المُعطى.
 
الشروع في اتصال TCP على المقبس المُعطى.
  
اسم مستعار يشير إلى socket.connect(options[, connectListener]) ويستدعى مع الخيار {port: port, host: host}.
+
اسم مستعار يشير إلى <code>socket.connect(options[, connectListener])‎</code> ويستدعى مع الخيار <code>options</code> بالقيمة <code>{port: port, host: host}</code>.
 
+
===<code>socket.connecting</code>===
=== <code>socket.connecting</code> ===
 
 
أضيفت في: v6.1.0
 
أضيفت في: v6.1.0
  
إذا كان قيمتها true فهذا يعني استدعاء socket.connect(options[, connectListener]) وأنه لم ينته بعد. وتصبح قيمتها false قبل انبعاث الحدث 'connect' و/أو استدعاء دالة رد الاتصال socket.connect(options[, connectListener]).
+
إذا كان قيمتها <code>true</code> فهذا يعني استدعاء <code>socket.connect(options[, connectListener])</code>‎ وأنه لم ينته بعد. وتصبح قيمتها <code>false</code> قبل انبعاث الحدث <code>'connect'</code> و/أو استدعاء دالة رد الاتصال <code>socket.connect(options[, connectListener])‎</code>.
 
+
===<code>socket.destroy([exception])‎</code>===
=== <code>socket.destroy([exception])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>exception</code> من النوع [[JavaScript/Object|<Object>]].
القيمة المُعادة: من النوع <net.Socket>.
+
* القيمة المُعادة: من النوع <code><net.Socket></code>.
 
 
 
وهو يضمن عدم حدوث أي نشاط إدخال/إخراج على هذا المقبس. ويُعد ضروريا فقط في حالة الأخطاء (خطأ تحليل أو نحو ذلك).
 
وهو يضمن عدم حدوث أي نشاط إدخال/إخراج على هذا المقبس. ويُعد ضروريا فقط في حالة الأخطاء (خطأ تحليل أو نحو ذلك).
  
إذا حُدِّد استثناءً exception، سيُطلق حدث 'error' وسيتلقى أي مستمع لهذا الحدث exception كوسيط.
+
إذا حُدِّد استثناءً <code>exception</code>، سيُطلق حدث <code>'error'</code> وسيتلقى أي مستمع لهذا الحدث <code>exception</code> كوسيط.
 
+
===<code>socket.destroyed</code>===
socket.destroyed
+
من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: ويشير إلى ما إذا كان الاتصال قد هُدِم أم لا. بمجرد هدم اتصال لا تُنقل أي بيانات باستخدامه.
 
+
===<code>socket.end([data][, encoding])‎</code>===
من النوع <boolean>: ويشير إلى ما إذا كان الاتصال قد هُدِم أم لا. بمجرد هدم اتصال لا تُنقل أي بيانات باستخدامه.
 
 
 
=== <code>socket.end([data][, encoding])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
 
 
 
 
تغلق المُقبس نصفيًا. أي أنه يرسل حزمة FIN. ومن الممكن أن يستمر الخادم في إرسال بعض البيانات.
 
تغلق المُقبس نصفيًا. أي أنه يرسل حزمة FIN. ومن الممكن أن يستمر الخادم في إرسال بعض البيانات.
  
إذا كانت data مُحددة، فإن ذلك يكافئ استدعاء socket.write(data, encoding) يتبعه socket.end()‎.
+
إذا كانت <code>data</code> مُحددة، فإن ذلك يكافئ استدعاء <code>socket.write(data, encoding)‎</code> يتبعه <code>socket.end()‎</code>.
 
+
===<code>socket.localAddress</code>===
<code>socket.localAddress</code>
+
أضيفت مع الإصدار: v0.9.6.
  
 +
وهو التمثيل النصي لعنوان IP المحلي الذي يتصل به العميل البعيد. على سبيل المثال، في خادم الاستماع إلى <code>'0.0.0.0'</code>، إذا اتصل عميل على <code>'192.168.1.1'</code>، ستتخذ <code>socket.localAddress</code> القيمة <code>'192.168.1.1'</code>.
 +
===<code>socket.localPort</code>===
 
أضيفت مع الإصدار: v0.9.6.
 
أضيفت مع الإصدار: v0.9.6.
  
وهو التمثيل النصي لعنوان IP المحلي الذي يتصل به العميل البعيد. على سبيل المثال، في خادم الاستماع إلى '0.0.0.0'، إذا اتصل عميل على '192.168.1.1'، ستتخذ socket.localAddress القيمة '192.168.1.1'.
+
التمثيل الرقمي للمنفذ المحلي. على سبيل المثال، <code>80</code> أو <code>21</code>.
 
+
===<code>socket.pause()‎</code>===
<code>socket.localPort</code>
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
 
+
إيقاف مؤقت لقراءة البيانات. بمعنى عدم إطلاق الأحداث <code>'data'</code>. وهو يفيد في خنق التحميل.
أضيفت مع الإصدار: v0.9.6
+
===<code>socket.ref()‎</code>===
 
 
التمثيل الرقمي للمنفذ المحلي. على سبيل المثال، 80 أو 21.
 
 
 
=== <code>socket.pause()‎</code> ===
 
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
 
 
 
إيقاف مؤقت لقراءة البيانات. بمعنى عدم إطلاق الأحداث 'data'. وهو يفيد في خنق التحميل.
 
 
 
=== <code>socket.ref()‎</code> ===
 
 
أُضيف مع الإصدار: v0.9.1.
 
أُضيف مع الإصدار: v0.9.1.
  
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
  
على عكس unref()‎، استدعاء ref()‎ على خادم سبق إجراء unref عليه لن يسمح للبرنامج بالانتهاء إذا كان هو الخادم الوحيد المتبقي (السلوك الافتراضي). استدعاء ref()‎ مرة أخرى على مقبس سبق إجراء ref عليه لن يكون له أي تأثير.
+
على عكس <code>unref()</code>‎، استدعاء <code>ref()</code>‎ على خادم سبق إجراء <code>unref</code> عليه لن يسمح للبرنامج بالانتهاء إذا كان هو الخادم الوحيد المتبقي (السلوك الافتراضي). استدعاء <code>ref()</code>‎ مرة أخرى على مقبس سبق إجراء <code>ref</code> عليه لن يكون له أي تأثير.
 
+
===<code>socket.remoteAddress</code>===
=== <code>socket.remoteAddress</code> ===
 
 
أُضيف مع الإصدار: v0.5.10.
 
أُضيف مع الإصدار: v0.5.10.
  
التمثيل النصي لعنوان IP البعيد. على سبيل المثال، '74.125.127.100" أو '2001:4860:a005::68'. قد تكون القيمة غير معرفة undefined إذا هُدِم المقبس (على سبيل المثال، إذا قُطع اتصال العميل).
+
التمثيل النصي لعنوان IP البعيد. على سبيل المثال، <code>'74.125.127.100'</code> أو <code>‎'2001:4860:a005::68'‎</code>. قد تكون القيمة غير معرفة <code>undefined</code> إذا هُدِم المقبس (على سبيل المثال، إذا قُطع اتصال العميل).
 
+
===<code>socket.remoteFamily</code>===
=== <code>socket.remoteFamily</code> ===
+
أُضيفت مع الإصدار: v0.11.14.
أُضيفت مع الإصدار: 0.11.14.
 
 
 
التمثيل النصي لأسرة IP البعيد. وتكون إما 'IPv4' أو 'IPv6'.
 
  
=== <code>socket.remotePort</code> ===
+
التمثيل النصي لعائلة IP البعيد. وتكون إما <code>'IPv4'</code> أو <code>'IPv6'</code>.
 +
===<code>socket.remotePort</code>===
 
أُضيف مع الإصدار: v0.5.10.
 
أُضيف مع الإصدار: v0.5.10.
  
التمثيل الرقمي للمنفذ البعيد. على سبيل المثال، 80 أو 21.
+
التمثيل الرقمي للمنفذ البعيد. على سبيل المثال، <code>80</code> أو <code>21</code>.
 
+
===<code>socket.resume()‎</code>===
=== <code>socket.resume()‎</code> ===
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
استئناف القراءة بعد استدعاء <code>socket.pause()</code>‎.
 
+
===<code>socket.setEncoding([encoding])‎</code>===
استئناف القراءة بعد استدعاء socket.pause()‎.
 
 
 
=== <code>socket.setEncoding([encoding])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
تعيين ترميز المقبس كدفق مقروء [[Node.js/stream|Readable Stream]]. راجع <code>[[Node.js/stream|readable.setEncoding()‎]]</code> لمزيد من المعلومات.
 
+
===<code>socket.setKeepAlive([enable][, initialDelay])‎</code>===
تعيين ترميز المقبس كدفق مقروء Readable Stream. راجع readable.setEncoding()‎ لمزيد من المعلومات.
 
 
 
=== <code>socket.setKeepAlive([enable][, initialDelay])‎</code> ===
 
 
أضيف مع الإصدار: v0.1.92.
 
أضيف مع الإصدار: v0.1.92.
 
+
* <code>enable</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>. القيمة الافتراضية: <code>false</code>.
enable من النوع <boolean>. القيمة الافتراضية: false.
+
* <code>initialDelay</code> من النوع <code>[[JavaScript/Number|<number>]]</code>. القيمة الافتراضية: <code>0</code>.
 
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
initialDelay من النوع <number>. القيمة الافتراضية: 0
 
 
 
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
 
 
 
 
تمكين أو تعطيل وظيفة المحافظة على الحياة، وتعيين التأخير المبدئي قبل إرسال أول تحقق من المحافظة على الحياة (keepalive probe) على مقبس خامل.
 
تمكين أو تعطيل وظيفة المحافظة على الحياة، وتعيين التأخير المبدئي قبل إرسال أول تحقق من المحافظة على الحياة (keepalive probe) على مقبس خامل.
  
ضبط initialDelay (بالمللي ثانية) لتعيين التأخير بين آخر حزمة بيانات واردة وأول تحقق من المحافظة على الحياة. وسيؤدي ضبط initialDelay بالقيمة 0 إلى ترك القيمة دون تغيير عن القيمة الافتراضية (أو القيمة السابقة).
+
ضبط <code>initialDelay</code> (بالمللي ثانية) لتعيين التأخير بين آخر حزمة بيانات واردة وأول تحقق من المحافظة على الحياة. وسيؤدي ضبط <code>initialDelay</code> بالقيمة <code>0</code> إلى ترك القيمة دون تغيير عن القيمة الافتراضية (أو القيمة السابقة).
 
+
===<code>socket.setNoDelay([noDelay])‎</code>===
=== <code>socket.setNoDelay([noDelay])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>noDelay</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>. القيمة الافتراضية: <code>true</code>.
noDelay من النوع <boolean>. القيمة الافتراضية: true.
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
 
+
تعطيل خوارزمية Nagle التي تستخدمها اتصالات TCP بشكل افتراضي، فتخزن البيانات مؤقتًا قبل إرسالها. ضبط <code>noDelay</code> بالقيمة <code>true</code> يُطلق البيانات فور استدعاء <code>socket.write()</code>‎.
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
===<code>socket.setTimeout(timeout[, callback])‎</code>===
 
 
تعطيل خوارزمية Nagle التي تستخدمها اتصالات TCP بشكل افتراضي، فتخزن البيانات مؤقتًا قبل إرسالها. ضبط noDelay بالقيمة true يُطلق البيانات فور استدعاء socket.write()‎.
 
 
 
=== <code>socket.setTimeout(timeout[, callback])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 +
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
 +
ضبط المقبس للانقضاء بعد مهلة <code>timeout</code> من الخمول على المقبس محسوبًا بالمللي ثانية. بشكل افتراضي لا تملك <code>net.Socket</code> مهلة للانقضاء.
  
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
عند إطلاق مهلة خمول، يتلقى المقبس حدث <code>'timeout'</code> ولكن لن ينقطع الاتصال. يجب على المستخدم استدعاء <code>socket.end()‎</code> أو <code>socket.destroy()</code>‎ يدوياً لإنهاء الاتصال.<syntaxhighlight lang="javascript">
 
+
socket.setTimeout(3000);
ضبط المقبس للانقضاء بعد مهلة timeout من الخمول على المقبس محسوبًا بالمللي ثانية. بشكل افتراضي لا تملك net.Socket مهلة للانقضاء.
+
socket.on('timeout', () => {
 
+
  console.log('socket timeout');
عند إطلاق مهلة خمول، يتلقى المقبس حدث 'timeout' ولكن لن ينقطع الاتصال. يجب على المستخدم استدعاء socket.end()‎ أو socket.destroy()‎ يدوياً لإنهاء الاتصال.
+
  socket.end();
 
+
});
إذا كانت timeout تساوي تتعطل مهلة الخمول الحالية.
+
</syntaxhighlight>إذا كانت <code>timeout</code> تساوي <code>0</code>، تتعطل مهلة الخمول الحالية.
 
 
يضاف المعامل callback الاختياري كمستمع لمرة واحدة لحدث 'timeout'.
 
  
=== <code>socket.unref()‎</code> ===
+
يضاف المعامل <code>callback</code> الاختياري كمستمع لمرة واحدة لحدث <code>'timeout'</code>.
 +
===<code>socket.unref()‎</code>===
 
أُضيف مع الإصدار: v0.9.1.
 
أُضيف مع الإصدار: v0.9.1.
 
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس نفسه.
القيمة المُعادة: <net.Socket> وهو المقبس نفسه.
+
يسمح استدعاء <code>unref()</code>‎ على مقبسٍ ما للبرنامج بالإنهاء إذا كان هو المقبس النشط الوحيد في نظام الأحداث. استدعاء <code>unref()‎</code> مرة أخرى على مقبس سبق إجراء <code>unref</code> عليه لن يكون له أي تأثير.
 
+
===<code>socket.write(data[, encoding][, callback])‎</code>===
يسمح استدعاء unref()‎ على مقبسٍ ما للبرنامج بالإنهاء إذا كان هو المقبس النشط الوحيد في نظام الأحداث. استدعاء unref()‎ مرة أخرى على مقبس سبق إجراء unref عليه لن يكون له أي تأثير.
 
 
 
=== <code>socket.write(data[, encoding][, callback])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>data</code> من النوع ‎<code>[[JavaScript/String|<string>]]</code> | <code>[[Node.js/buffer|<Buffer>]]</code> | <code>[https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array <Uint8Array>]</code>‎.
data من النوع <string> | <Buffer> | <Uint8Array>.
+
* <code>encoding</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وتستخدم فقط عندما تكون <code>data</code> من النوع <code>string</code>. القيمة الافتراضية: <code>utf8</code>.
 
+
* <code>callback</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>.
encoding من النوع <string>: وتستخدم فقط عندما تكون data من النوع string. القيمة الافتراضية: utf8.
+
* القيمة المُعادة: من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>.
 
 
callback من النوع <Function>.
 
 
 
القيمة المُعادة: من النوع <boolean>.
 
 
 
 
إرسال البيانات على مقبس. ويحدد المعامل الثاني الترميز في حالة أن تكون البيانات سلسلة — ويكون الترميز UTF8 في الوضع الافتراضي.
 
إرسال البيانات على مقبس. ويحدد المعامل الثاني الترميز في حالة أن تكون البيانات سلسلة — ويكون الترميز UTF8 في الوضع الافتراضي.
  
ويعيد true إذا انتقلت البيانات بالكامل بنجاح إلى مخزن النواة المؤقت (kernel buffer). ويعيد false إذا كان كل أو جزء من البيانات في قائمة الانتظار في ذاكرة المستخدم. ويُطلق الحدث 'drain' عندما يكون المحزن المؤقت متاحًا مرة أخرى.
+
ويعيد <code>true</code> إذا انتقلت البيانات بالكامل بنجاح إلى مخزن النواة المؤقت (kernel buffer). ويعيد <code>false</code> إذا كان كل أو جزء من البيانات في قائمة الانتظار في ذاكرة المستخدم. ويُطلق الحدث 'drain' عندما يكون المحزن المؤقت متاحًا مرة أخرى.
 
 
وسينفذ معامل رد الاتصال callback الاختياري عند الانتهاء من كتابة البيانات خارجًا--وقد لا حدث هذا فورًا.
 
  
راجع التابع write()‎ وهو تابع التيار القابل للكتابةWritable Stream ‎ للحصول على مزيد من المعلومات.
+
وسينفذ معامل رد الاتصال <code>callback</code> الاختياري عند الانتهاء من كتابة البيانات خارجًا--وقد لا حدث هذا فورًا.
  
== <code>net.connect()‎</code> ==
+
راجع التابع <code>write()‎</code> وهو تابع التيار القابل للكتابة <code>Writable</code> Stream‎ للحصول على مزيد من المعلومات.
 +
==<code>net.connect()‎</code>==
 
الأسماء المستعارة للتابع <code>net.createConnection()</code>‎.
 
الأسماء المستعارة للتابع <code>net.createConnection()</code>‎.
  
 
الأشكال الممكنة:
 
الأشكال الممكنة:
 +
* <code>net.connect(options[, connectListener])‎</code>
 +
* <code>net.connect(path[, connectListener])‎</code> لاتصالات IPC.
 +
* <code>net.connect(port[, host][, connectListener])‎</code> لاتصالات TCP.
  
<code>net.connect(options[, connectListener])‎</code>
+
===<code>net.connect(options[, connectListener])‎</code>===
 
 
<code>net.connect(path[, connectListener])‎</code> لاتصالات IPC.
 
 
 
<code>net.connect(port[, host][, connectListener])‎</code> لاتصالات TCP.
 
 
 
=== <code>net.connect(options[, connectListener])‎</code> ===
 
 
أُضيف مع الإصدار: v0.7.0.
 
أُضيف مع الإصدار: v0.7.0.
  
الاسم المستعار للتابع net.createConnection(options[, connectListener])‎.
+
الاسم المستعار للتابع <code>net.createConnection(options[, connectListener])‎</code>.
 
+
===<code>net.connect(path[, connectListener])‎</code>===
=== <code>net.connect(path[, connectListener])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
الاسم المستعار للتابع net.createConnection(path[, connectListener])‎.
+
الاسم المستعار للتابع <code>net.createConnection(path[, connectListener])‎</code>.
 
+
===<code>net.connect(port[, host][, connectListener])‎</code>===
=== <code>net.connect(port[, host][, connectListener])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
  
الاسم المستعار للتابع net.createConnection(port[, host][, connectListener])‎.
+
الاسم المستعار للتابع <code>net.createConnection(port[, host][, connectListener])‎</code>.
 
+
==<code>net.createConnection()‎</code>==
== <code>net.createConnection()‎</code> ==
+
وهي دالة تصنيع، تنشئ <code>net.Socket</code> جديدة، وهي تهيئ اتصال مع <code>socket.connect()</code>‎، ثم تعيد <code>net.Socket</code> الذي يبدأ الاتصال.
وهي دالة تصنيع، تنشئ net.Socket جديدة، وهي تهيئ اتصال مع socket.connect()‎، ثم تعيد net.Socket الذي يبدأ الاتصال.
 
  
عند تأسيس الاتصال، سيُطلق الحدث 'connect' على المقبس المُعاد. وسيضاف المعامل الأخير connectListener، إذا توفَّر، كمستمع للحدث 'connect' مرة واحدة.
+
عند تأسيس الاتصال، سيُطلق الحدث <code>'connect'</code> على المقبس المُعاد. وسيضاف المعامل الأخير <code>connectListener</code>، إذا توفَّر، كمستمع للحدث <code>'connect'</code> مرة واحدة.
  
 
الأشكال الممكنة:
 
الأشكال الممكنة:
 
+
* <code>net.createConnection(options[, connectListener])‎</code>
<code>net.createConnection(options[, connectListener])‎</code>
+
* <code>net.createConnection(path[, connectListener])‎</code> لاتصالات IPC.
 
+
* <code>net.createConnection(port[, host][, connectListener])‎</code> لاتصالات TCP.
<code>net.createConnection(path[, connectListener])‎</code> لاتصالات IPC.
+
الدالة <code>net.connect()‎</code> هي اسم مستعار لهذه الدالة.
 
+
===<code>net.createConnection(options[, connectListener])‎</code>===
<code>net.createConnection(port[, host][, connectListener])‎</code> لاتصالات TCP.
 
 
 
الدالة net.connect()‎ هي اسم مستعار لهذه الدالة.
 
 
 
=== <code>net.createConnection(options[, connectListener])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>options</code> من النوع <code>[[JavaScript/Object|<Object>]]</code>: ويجب إدخالها. ستمرر إلى كل من استدعاء <code>new net.Socket([options])</code>‎ والتابع <code>socket.connect(options[, connectListener])</code>‎.
options من النوع <nowiki><Object>: ويجب إدخالها. ستمرر إلى كل من استدعاء new net.Socket([options]) والتابع socket.connect(options[, connectListener]).</nowiki>
+
* <code>connectListener</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع للدالة <code>net.createConnection()‎</code>. إذا توفَّرت، ستضاف كمستمع للحدث <code>'connect'</code> على المقبس المُعاد مرة واحدة.
 
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.
connectListener من النوع <Function>: وهو معامل شائع للدالة net.createConnection()‎. إذا توفَّرت، ستضاف كمستمع للحدث 'connect' على المقبس المُعاد مرة واحدة.
+
للخيارات المتاحة، انظر <code>new net.Socket([options])‎</code> و <code>socket.connect(options[, connectListener])</code>.
 
 
القيمة المُعادة: <net.Socket>: المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.
 
 
 
للخيارات المتاحة، انظر new net.Socket([options]) و socket.connect(options[, connectListener])
 
  
 
خيارات إضافية:
 
خيارات إضافية:
 +
* <code>timeout</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: إذا ضُبِط، سيستخدم لاستدعاء <code>socket.setTimeout(timeout)‎</code> بعد إنشاء مقبس، ولكن قبل أن يبدأ الاتصال.
 +
فيما يلي مثال لعميل خادم صدى (echo server) الموصوف في قسم <code>()‎‎net.createServer</code>:<syntaxhighlight lang="javascript">
 +
const net = require('net');
 +
const client = net.createConnection({ port: 8124 }, () => {
 +
  // 'connect' مستمع
 +
  console.log('التوصيل مع الخادم!');
 +
  client.write('أيها العالم!\r\n');
 +
});
 +
client.on('data', (data) => {
 +
  console.log(data.toString());
 +
  client.end();
 +
});
 +
client.on('end', () => {
 +
  console.log('قطع الإتصال مع الخادم');
 +
});
 +
</syntaxhighlight>للاتصال على المقبس <code>‎/tmp/echo.sock</code> يجب تغيير السطر الثاني فقط إلى:<syntaxhighlight lang="javascript">
 +
const client = net.createConnection({ path: '/tmp/echo.sock' });
 +
</syntaxhighlight>
  
timeout من النوع <number>: إذا ضُبِط، سيستخدم لاستدعاء socket.setTimeout(timeout) بعد إنشاء مقبس، ولكن قبل أن يبدأ الاتصال.
+
===<code>net.createConnection(path[, connectListener])‎</code>===
 
 
فيما يلي مثال لعميل خادم صدى (echo server) الموصوف في قسم()‎‎ net.createServer:
 
 
 
للاتصال على المقبس ‎/tmp/echo.sock يجب تغيير السطر الثاني فقط إلى:
 
 
 
=== <code>net.createConnection(path[, connectListener])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>path</code> من النوع <code>[[JavaScript/String|<string>]]</code>: وهو المسار الذي يجب على المقبس الاتصال به. سيُمرر إلى <code>socket.connect(path[, connectListener])‎</code>. راجع تحديد مسارات اتصالات IPC.
path من النوع <string>: وهو المسار الذي يجب على المقبس الاتصال به. سيُمرر إلى socket.connect(path[, connectListener]). راجع تحديد مسارات اتصالات IPC.
+
* <code>connectListener</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع لدوال <code>net.createConnection()</code>‎ وهو مستمع "لمرة واحدة" للحدث <code>'connect'</code> المقبس البادئ. سيُمرر إلى <code>socket.connect(path[, connectListener])‎</code>.
 
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.
connectListener من النوع <Function>: وهو معامل شائع لدوال net.createConnection()‎ وهو مستمع "لمرة واحدة" للحدث 'connect' المقبس البادئ. سيُمرر إلى socket.connect(path[, connectListener]).
 
 
 
القيمة المُعادة: <net.Socket> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.
 
 
 
 
يبدأ إجراء اتصال IPC.
 
يبدأ إجراء اتصال IPC.
  
تُنشئ هذه الدالة net.Socket مع جميع الخيارات مضبوطة بالقيم الافتراضية، وتبدأ الاتصال مع socket.connect(path[, connectListener]) على الفور، ثم تعيد net.Socket والذي يبدأ الاتصال.
+
تُنشئ هذه الدالة <code>net.Socket</code> مع جميع الخيارات مضبوطة بالقيم الافتراضية، وتبدأ الاتصال مع <code>socket.connect(path[, connectListener])‎</code> على الفور، ثم تعيد <code>net.Socket</code> والذي يبدأ الاتصال.
 
+
===<code>net.createConnection(port[, host][, connectListener])‎</code>===
=== <code>net.createConnection(port[, host][, connectListener])‎</code> ===
 
 
أُضيف مع الإصدار: v0.1.90.
 
أُضيف مع الإصدار: v0.1.90.
 
+
* <code>port</code> من النوع <code>[[JavaScript/Number|<number>]]</code>: وهو المنفذ الذي يجب على المقبس الاتصال به. سيُمرر إلى <code>socket.connect(port[, host][, connectListener])‎</code>.
port من النوع <number>: وهو المنفذ الذي يجب على المقبس الاتصال به. سيُمرر إلى socket.connect(port[, host][, connectListener]).
+
* <code>host</code> من النوع <string>: وهو المضيف الذي الذي يجب على المقبس الاتصال به. سيُمرر إلى <code>socket.connect(port[, host][, connectListener])‎</code>. القيمة الافتراضية: <code>'localhost'</code>.
 
+
* <code>connectListener</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو معامل شائع لدوال <code>net.createConnection()‎</code> وهو مستمع "لمرة واحدة" للحدث <code>'connect'</code> المقبس البادئ. سيُمرر إلى <code>socket.connect(path[, connectListener])‎</code>.
host من النوع <string>: وهو المضيف الذي الذي يجب على المقبس الاتصال به. سيُمرر إلى socket.connect(port[, host][, connectListener]). القيمة الافتراضية: 'localhost'.
+
* القيمة المُعادة: <code><net.Socket></code> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.
 
 
connectListener من النوع <Function>: وهو معامل شائع لدوال net.createConnection()‎ وهو مستمع "لمرة واحدة" للحدث 'connect' المقبس البادئ. سيُمرر إلى socket.connect(path[, connectListener]).
 
 
 
القيمة المُعادة: <net.Socket> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.
 
 
 
 
يبدأ اتصال TCP.
 
يبدأ اتصال TCP.
  
تُنشئ هذه الدالة net.Socket مع جميع الخيارات مضبوطة بالقيم الافتراضية، وتبدأ الاتصال مع socket.connect(port[, host][, connectListener]) على الفور، ثم تعيد net.Socket والذي يبدأ الاتصال.
+
تُنشئ هذه الدالة <code>net.Socket</code> مع جميع الخيارات مضبوطة بالقيم الافتراضية، وتبدأ الاتصال مع <code>socket.connect(port[, host][, connectListener])‎</code> على الفور، ثم تعيد <code>net.Socket</code> والذي يبدأ الاتصال.
 
+
==<code>net.createServer([options][, connectionListener])‎</code>==
== <code>net.createServer([options][, connectionListener])‎</code> ==
 
 
أُضيف مع الإصدار: v0.5.0.
 
أُضيف مع الإصدار: v0.5.0.
  
 
إنشاء خادم TCP أو IPC جديد.
 
إنشاء خادم TCP أو IPC جديد.
 +
* <code>options</code> من النوع  <code>[[JavaScript/Object|<Object>]]</code>.
 +
* <code>allowHalfOpen</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وهو يشير إلى ما إذا كان مسموح باتصالات TCP مفتوحة نصفيا. القيمة الافتراضية: <code>false</code>.
 +
* <code>pauseOnConnect</code> من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>: وهو يحدد ما إذا كان يجب إيقاف المقبس مؤقتا عن الاتصالات الواردة .القيمة الافتراضية: <code>false</code>.
 +
* <code>connectionListener</code> من النوع <code>[[JavaScript/Function|<Function>]]</code>: وهو يضبط مستمع للحدث <code>'connection'</code> تلقائيا.
 +
* القيمة المُعادة: من النوع <code><net.Server></code>.
 +
إذا ضُبط <code>allowHalfOpen</code> بالقيمة <code>true</code> عندما يرسل الطرف الآخر من المقبس حزمة FIN، يرسل الخادم حزمة FIN فقط عند استدعاء <code>socket.end()‎</code> صراحة وحتى هذا الحين يكون الاتصال مغلقًا نصفيًا (غير مقروء ولكن لا يزال قابل للكتابة). انظر الحدث <code>'end'</code> و RFC 1122 (القسم 4.2.2.13) لمزيد من المعلومات.
  
options من النوع  <Object>.
+
إذا ضُبط <code>pauseOnConnect</code> بالقيمة <code>true</code>، سيتوقف المقبس المرتبط مع كل اتصال وارد مؤقتا، ولن تُقرأ أي بيانات من معالجها. ويسمح هذا للاتصالات بالمرور بين العمليات دون قراءة أي بيانات من قِبَل العملية الأصلية. للبدء في قراءة البيانات من مقبس متوقف مؤقتاً، يجب استدعاء <code>socket.resume()</code>.
  
allowHalfOpen من النوع <boolean>: وهو يشير إلى ما إذا كان مسموح باتصالات TCP مفتوحة نصفيا. القيمة الافتراضية: false.
+
يمكن أن يكون الخادم TCP أو IPC اعتماداً على ما يستمع إليه بواسطة <code>listen()</code>.
  
pauseOnConnect من النوع <boolean>: وهو يحدد ما إذا كان يجب إيقاف المقبس مؤقتا عن الاتصالات الواردة .القيمة الافتراضية: false.
+
إليك مثال على صدى خادم TCP والذي يستمع للاتصالات على المنفذ 8124:<syntaxhighlight lang="javascript">
 
+
const net = require('net');
connectionListener من النوع <Function>: وهو يضبط مستمع للحدث 'connection' تلقائيا.
+
const server = net.createServer((c) => {
 
+
  // 'connection' مستمع
القيمة المُعادة: من النوع <net.Server>.
+
  console.log('إتصال العميل');
 
+
  c.on('end', () => {
إذا ضُبط allowHalfOpen بالقيمة true عندما يرسل الطرف الآخر من المقبس حزمة FIN، يرسل الخادم حزمة FIN فقط عند استدعاء socket.end()‎ صراحة وحتى هذا الحين يكون الاتصال مغلقًا نصفيًا (غير مقروء ولكن لا يزال قابل للكتابة). انظر الحدث 'end' و <nowiki>RFC 1122</nowiki> (القسم 4.2.2.13) لمزيد من المعلومات.
+
    console.log('قطع إتصال العميل');
 
+
  });
إذا ضُبط pauseOnConnect بالقيمة true، سيتوقف المقبس المرتبط مع كل اتصال وارد مؤقتا، ولن تُقرأ أي بيانات من معالجها. ويسمح هذا للاتصالات بالمرور بين العمليات دون قراءة أي بيانات من قِبَل العملية الأصلية. للبدء في قراءة البيانات من مقبس متوقف مؤقتاً، يجب استدعاء socket.resume()‎.
+
  c.write('مرحبًا\r\n');
 
+
  c.pipe(c);
يمكن أن يكون الخادم TCP أو IPC اعتماداً على ما يستمع إليه بواسطة listen().
+
});
 
+
server.on('error', (err) => {
إليك مثال على صدى خادم TCP والذي يستمع للاتصالات على المنفذ 8124:
+
  throw err;
 
+
});
اختبر هذا باستخدام telnet:
+
server.listen(8124, () => {
 
+
  console.log('الخادم مرتبط');
للاستماع على المقبس ‎/tmp/echo.sock يجب تغيير السطر الثالث من النهاية فقط إلى:
+
});
 
+
</syntaxhighlight>اختبر هذا باستخدام telnet:<syntaxhighlight lang="bash">
ويستخدم nc للاتصال بخادم مقبس مجال UNIX:
+
$ telnet localhost 8124
 +
</syntaxhighlight>للاستماع على المقبس <code>‎/tmp/echo.sock</code> يجب تغيير السطر الثالث من النهاية فقط إلى:<syntaxhighlight lang="javascript">
 +
server.listen('/tmp/echo.sock', () => {
 +
  console.log('الخادم مرتبط');
 +
});
 +
</syntaxhighlight>ويستخدم <code>nc</code> للاتصال بخادم مقبس مجال UNIX:<syntaxhighlight lang="bash">
 +
$ nc -U /tmp/echo.sock
 +
</syntaxhighlight>
  
== <code>net.isIP(input)‎</code> ==
+
==<code>net.isIP(input)‎</code>==
 
أُضيف مع الإصدار: v0.3.0.
 
أُضيف مع الإصدار: v0.3.0.
 
+
* القيمة المُعادة: من النوع <code>[[JavaScript/Number|<integer>]]</code>.
القيمة المُعادة: من النوع <integer>.
+
تُعيد الاختبارات إذا كان المُدخَل عنوان IP القيمة <code>0</code> للسلاسل النصية غير الصالحة، و <code>4</code> لعناوين IP من الإصدار 4 و <code>6</code> لعناوين IP من الإصدار 6.
 
+
==<code>net.isIPv4(input)‎</code>==
تُعيد الاختبارات إذا كان المُدخَل عنوان IP القيمة 0 للسلاسل النصية غير الصالحة، و 4 لعناوين IP من الإصدار 4 و 6 لعناوين IP من الإصدار 6.
 
 
 
== <code>net.isIPv4(input)‎</code> ==
 
 
أُضيف مع الإصدار: v0.3.0.
 
أُضيف مع الإصدار: v0.3.0.
 
+
* القيمة المُعادة: من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>
القيمة المُعادة: من النوع <boolean>.
+
تُعيد <code>true</code> في حالة إدخال عنوان IP من الإصدار 4، وإلا سيُعيد <code>false</code>.
 
+
==<code>net.isIPv6(input)‎</code>==
تُعيد true في حالة إدخال عنوان IP من الإصدار 4، وإلا سيُعيد false.
 
 
 
== <code>net.isIPv6(input)‎</code> ==
 
 
أُضيف مع الإصدار: v0.3.0.
 
أُضيف مع الإصدار: v0.3.0.
 +
* القيمة المُعادة: من النوع <code>[[JavaScript/Boolean|<boolean>]]</code>.
 +
<span> </span>تُعيد <code>true</code> في حالة إدخال عنوان IP من الإصدار 6، وإلا سيُعيد <code>false</code>.
  
القيمة المُعادة: من النوع <boolean>.
+
== مصادر ==
 
+
* [https://nodejs.org/dist/latest-v10.x/docs/api/net.html صفحة الوحدة Net في توثيق Node.js الرسمي].
تُعيد true في حالة إدخال عنوان IP من الإصدار 6، وإلا سيُعيد false.
+
[[تصنيف:Node.js|{{SUBPAGENAME}}]]

المراجعة الحالية بتاريخ 11:19، 23 أكتوبر 2018

مؤشر الاستقرار: 2 - مستقر.

توفر الوحدة net واجهة تطبيقات لشبكة اتصال غير متزامن لإنشاء خوادم قائمة على تدفق اتصالات TCP أو IPC أي (net.createServer()‎) والعملاء (net.createConnection()‎).

ويمكن الوصول إليه باستخدام:

const net = require('net');

دعم اتصالات IPC

تدعم وحدة net اتصالات IPC بواسطة الأنابيب المُسماة (named pipes) في ويندوز، أو مقابس مجالات يونكس (UNIX domain sockets) في أنظمة التشغيل الأخرى.

تحديد مسارات اتصالات IPC

تحتاج التوابع net.connect()‎ و net.createConnection()‎ و server.listen()‎ و socket.connect()‎ المعامل path لتحديد نهايات اتصالات IPC.

يُعرف النطاق المحلي في UNIX بنطاق UNIX. ويكون المسار هو اسم مسار نظام الملفات. ويجري اقتصاصها إلى حجم يساوي sizeof(sockaddr_un.sun_path)-1، والذي يختلف من نظام تشغيل إلى آخر بين 91 و 107 بايت. القيم النموذجية هي 107 في نظام لينكس و 103 في نظام macOS. ويخضع المسار لنفس اصطلاحات التسمية وفحص الأذونات بنفس كيفية إنشاء ملف. إذا أُنشئ مقبس مجال UNIX (الذي يكون مرئياً كمسار نظام ملف) واستُخدم بالاقتران مع أحد تجريديات واجهات تطبيقات Node.js مثل net.createServer()‎، سينقطع ارتباطه كجزء من server.close()‎. من ناحية أخرى، إذا أُنشئ واستُخدم خارج هذه التجريديات، سوف يحتاج المستخدم لإزالته يدويًا. وينطبق الشيء نفسه عند إنشاء المسار من قِبَل واجهات تطبيقات Node.js ولكن البرنامج يتعطل فجأة. وباختصار، سيظهر مقبس مجال UNIX في نظام الملفات تم إنشاءه بنجاح، وسوف يستمر حتى يقطع ارتباطه.

في ويندوز، يتحقق النطاق المحلي باستخدام أنبوب مُسمّى. يجب أن يشير المسار إلى مُدخل في ‎\\?\pipe\‎ أو ‎\\.\pipe\‎. مسموح بأي حروف، ولكن قد يجري هذا الأخير بعض المعالجة لأسماء الأنابيب مثل أن يُترجم متواليات .. . على الرغم من كيف يمكن أن تبدو، فإن مجال أسماء الأنابيب مسطحة. لن تستمر الأنابيب. وتُزال عند إغلاق آخر مرجع إليها. على عكس مقابس مجال UNIX، يُغلق ويندوز الأنابيب ويُزيلها عند انتهاء العملية المالكة.

يتطلب الهروب من سلسلة JavaScript مسارات محددة باستخدام شرطة هروب مائلة عكسية \ إضافية مثل:

net.createServer().listen(
  path.join('\\\\?\\pipe', process.cwd(), 'myctl'));

الصنف net.Server

أُضيف مع الإصدار: v0.1.90.

يستخدم هذا الصنف لإنشاء خادم TCP أو IPC.

new net.Server([options][, connectionListener])‎

  • options ‏‎<Object>‎: راجع net.createServer([options][, connectionListener])‎.
  • connectionListener‏ <Function>: ضبط الدالة تلقائيًا كمستمع للحدث 'connection'.
  • القيمة المُعادة: من النوع <net.Server>.

ويُعد net.Server هو EventEmitter مع الأحداث التالية:

الحدث 'close'

أُضيف مع الإصدار: v0.5.0.

يُطلَق عند إغلاق الخادم. لاحظ أنه في حالة وجود اتصالات، لا ينطلق هذا الحدث حتى إنهاء كافة الاتصالات.

الحدث 'connection'

أُضيف مع الإصدار: v0.1.90.

  • <net.Socket>: وهو كائن الاتصال.

يُطلَق عند إجراء اتصال جديد. ويكون socket مثيل net.Socket.

الحدث 'error'

أُضيف مع الإصدار: v0.1.90.

يُطلَق عند حدوث خطأ ما. على عكس net.Socket لا يصدر الحدث 'close' مباشرة بعد هذا الحدث إلا إذا اُستدعيَ server.close()‎ يدويًا. راجع المثال في شرح server.listen()‎.

الحدث: 'listening'

أُضيف مع الإصدار: v0.1.90.

يُطلَق عند ربط الخادم بعد استدعاء server.listen()‎.

server.address()‎

أُضيف مع الإصدار: v0.1.90.

يعيد العنوان address المنضم واسم عائلة العنوان family ومنفذ الخادم port كما يذكره نظام التشغيل إذا كان يستمع إلى مقبس IP (وهو يفيد في العثور على أي منفذ الذي عُيّن عند الحصول على عنوان مُعيَّن من قِبل نظام التشغيل): ‎{ port: 12346, family: 'IPv4', address: '127.0.0.1' }‎.

بالنسبة لخادم يستمع إلى أنابيب أو مقبس نطاق UNIX، يُعاد الاسم كسلسلة نصية.

على سبيل المثال:

const server = net.createServer((socket) => {
  socket.end('goodbye\n');
}).on('error', (err) => {
  // معالجة الأخطاء هنا
  throw err;
});

// انتزاع منفذ غير مستخدم عشوائيًا.
server.listen(() => {
  console.log('opened server on', server.address());
});

لا يجب استدعاء server.address()‎ حتى ينطلق الحدث 'listening'.

server.close([callback])‎

أُضيف مع الإصدار: v0.1.90.

  • callback‏ <Function>: الدالة التي ستستدعى عند إغلاق الاتصال مع الخادم.
  • القيمة المُعادة: من النوع <net.Server>.

يمنع الخادم من قبول اتصالات جديدة ويحافظ على الاتصالات الموجودة. وهو دالة غير متزامنة، ويُغلَق الخادم أخيراً عند إنهاء كافة الاتصالات ويُطلِق الخادم حدث 'close'. وتُستدعى دالة رد الاتصال callback الاختيارية بمجرد حدوث الحدث 'close'. على عكس هذا الحدث ستستدعى مع Error كوسيط وحيد إذا كان الخادم غير مفتوح عند إغلاقه.

server.connections (مُهمَل)

أُضيف مع الإصدار: v0.2.0، وأُهمِل مع الإصدار: v0.9.7.

مؤشر الاستقرار: 0 - مُهمل: يُستخدم server.getConnections()‎ بدلاً منه.

عدد الاتصالات المتزامنة مع الخادم.

ويصبح null عند إرسال مقبس لأحد الأبناء بواسطة التابع child_process.fork()‎. لاستطلاع التفرعات والحصول على العدد الحالي من الاتصالات النشطة يستخدم التابع server.getConnections()‎ غير المتزامن بدلاً من ذلك.

server.getConnections(callback)‎

أُضيف مع الإصدار: v0.9.7.

  • القيمة المُعادة: من النوع <net.Server>.

يعيد بشكل غير متزامن عدد الاتصالات المتزامنة مع الخادم. يعمل عند إرسال مقبس التوصيل إلى التفريعات.

يجب تمرير وسيطين لدالة رد الاتصال err و count.

server.listen()‎

بدء تشغيل خادم يستمع للاتصالات. يمكن أن يكون net.Server خادم TCP أو IPC اعتمادًا على ما يستمع إليه.

الأشكال الممكنة:

  • server.listen(handle[, backlog][, callback])‎
  • server.listen(options[, callback])‎
  • server.listen(path[, backlog][, callback])‎ لخوادم IPC.
  • server.listen([port[, host[, backlog]]][, callback])‎ لخوادم TCP.

هذه الدالة غير متزامنة. عند بدء الخادم في الاستماع، يُطلق حدث 'listening'. وسيضاف المعامل الأخير callback كمستمع للحدث 'listening'.

يمكن أن تأخذ جميع توابع listen()‎‎ معامل تراكم backlog لتعيين الحد الأقصى لطول قائمة الانتظار للاتصالات المعلقة. وستُحدد المدة الفعلية من قِبل نظام التشغيل من خلال إعدادات sysctl مثل tcp_max_syn_backlog و somaxconn في Linux. وتكون القيمة الافتراضية لهذا المعامل 511 (وليس 512).

وتُضبط جميع net.Socket على SO_REUSEADDR (انظر socket(7)‎ لمزيد من التفاصيل).

يمكن استدعاء التابع server.listen()‎ مرة أخرى إذا وفقط إذا كان هناك خطأ أثناء استدعاء server.listen()‎ الأول أو استدعاء server.close()‎. خلاف ذلك، سيُطلق خطأ ERR_SERVER_ALREADY_LISTEN.

أحد الأخطاء الأكثر شيوعاً التي أثيرت عند الاستماع هو EADDRINUSE. ويحدث هذا عند استماع خادم آخر على port/path/handle المطلوبين. أحد طرق التعامل مع ذلك يكون بإعادة المحاولة بعد فترة معينة من الزمن:

server.on('error', (e) => {
  if (e.code === 'EADDRINUSE') {
    console.log('Address in use, retrying...');
    setTimeout(() => {
      server.close();
      server.listen(PORT, HOST);
    }, 1000);
  }
});

server.listen(handle[, backlog][, callback])‎

أُضيف مع الإصدار: v0.5.10.

  • handle من النوع <Object>.
  • backlog من النوع <number>: وهو معامل شائع لدوال server.listen()‎.
  • callback من النوع <Function>: وهو معامل شائع لدوال server.listen()‎.
  • القيمة المُعادة: من النوع <net.Server>.

بدء تشغيل خادم للاستماع للاتصالات على handle سبق ربطه مع منفذ، أو مقبس نطاق UNIX، أو أنبوب ويندوز المسمى.

يمكن أن يكون الكائن handle أما خادم أو مقبس (أي شيء مع عضو ‎_handle أساسي) أو كائن مع عضو fd يكون واصف ملف صالح.

ولا يدعم ويندوز الاستماع إلى واصف ملف.

server.listen(options[, callback])‎

أُضيفت مع الإصدار: 0.11.14.

  • options من النوع <Object>: ويجب إدخاله. وهو يدعم الخصائص التالية:
    • port من النوع <number>.
    • host من النوع <string>.
    • path من النوع <string>: سيُتجاهل إذا حُدِد port. راجع تحديد مسارات اتصالات IPC.
    • backlog من النوع <number>: وهو معامل شائع لدوال server.listen()‎.
    • exclusive من النوع <boolean>. وتكون القيمة الافتراضية: false.
    • readableAll من النوع <boolean>: وهو يجعل الأنابيب مقروءة لجميع المستخدمين في خوادم IPC. وتكون القيمة الافتراضية: false.
    • writableAll من النوع <boolean>: وهو يجعل الأنابيب قابلة للكتابة لجميع المستخدمين في خوادم IPC. وتكون القيمة الافتراضية: false.
  • callback من النوع <Function> وهو معامل شائع لدوال server.listen()‎.
  • القيمة المُعادة: من النوع <net.Server>.

إذا حُدد port، فإنه يتصرف بنفس أسلوب server.listen([port[, host[, backlog]]][, callback])‎. وبخلاف ذلك، إذا حُدد path، فإنه يتصرف بنفس أسلوب server.listen(path[, backlog][, callback])‎. وإذا لم يحدد أي منهما، سيُطلَق خطأ.

إذا كانت قيمة exclusive هي false (افتراضيًا)، ستستخدم مشغلات العنقود نفس المعالج الأساسي، سامحًا بمشاركة مهام معالجة الاتصال. أما إذا كانت قيمة exclusive هي true، فلا تُشارَك المُعالج، وتؤدي محاولة مشاركة المنفذ إلى خطأ. فيما يلي مثال على الاستماع إلى منفذ حصري:

server.listen({
  host: 'localhost',
  port: 80,
  exclusive: true
});

قد يتسبب بدء تشغيل خادم IPC كجذر في أن يكون مسار الخادم غير قابل للوصول للمستخدمين غير المتمتعين بامتيازات. سيؤدي استخدام readableAll و writableAll إلى أن يكون الخادم في متناول جميع المستخدمين.

server.listen(path[, backlog][, callback])‎

أُضيف مع الإصدار: v0.1.90.

  • path من النوع <string>: وهو المسار الذي يجب على الخادم الاستماع إليه. راجع تحديد مسارات اتصالات IPC.
  • backlog من النوع <number>: وهو معامل شائع لدوال server.listen()‎.
  • callback من النوع <Function>: وهو معامل شائع لدوال server.listen()‎.
  • القيمة المُعادة: من النوع <net.Server>.

بدء تشغيل خادم IPC للاستماع للاتصالات على path معين.

server.listen([port[, host[, backlog]]][, callback])‎

أُضيف مع الإصدار: v0.1.90.

  • port من النوع <number>.
  • host من النوع <string>.
  • backlog من النوع <number> وهو معامل شائع لدوال server.listen()‎.
  • callback من النوع <Function>: وهو معامل شائع لدوال server.listen()‎.
  • القيمة المُعادة: من النوع <net.Server>.

بدء تشغيل خادم TCP للاستماع للاتصالات على port و host معينين.

إذا حُذف المنفذ port أو كان 0، سيُعين نظام التشغيل منفذ عشوائي غير مستخدم، والذي يمكن استعادته باستخدام server.address()‎‎.port بعد إطلاق الحدث 'listening'.

إذا حُذف المضيف host، سيقبل الخادم الاتصالات على عنوان IPv6 غير محدد (::) عندما يتوفر IPv6، أو عنوان IPv4 غير محدد (0.0.0.0) خلاف ذلك.

في معظم أنظمة التشغيل قد يتسبب الاستماع إلى عنوان IPv6 غير محدد (::) في استماع net.Server أيضا إلى عنوان IPv4 غير محدد (0.0.0.0).

server.listening

أُضيفت مع الإصدار: v5.7.0.

  • من النوع <boolean>: وهو يشير إلى ما إذا كان الخادم يستمع للاتصالات أم لا.

server.maxConnections

أضيفت مع الإصدار: v0.2.0.

تُضبط هذه الخاصية لرفض الاتصالات عندما يكون عدد الاتصالات بالخادم كبيرًا.

من غير المستحسن استخدام هذا الخيار عند إرسال مقبس إلى أحد الأبناء خلال child_process.fork()‎.

server.ref()‎

أُضيف مع الإصدار: v0.9.1.

  • القيمة المُعادة: من النوع <net.Server>.

على عكس unref()‎، استدعاء ref()‎ على خادم سبق إجراء unref عليه لن يسمح للبرنامج بالانتهاء إذا كان هو الخادم الوحيد المتبقي (السلوك الافتراضي). أما استدعاء ref()‎ مرة أخرى على خادم سبق إجراء ref عليه فلن يكون له أي تأثير.

server.unref()‎

أُضيف مع الإصدار: v0.9.1.

  • القيمة المُعادة: من النوع <net.Server>.

يسمح استدعاء unref()‎ على خادم للبرنامج بالإنهاء إذا كان هو الخادم النشط الوحيد في نظام الأحداث. أما  استدعاء unref()‎ مرة أخرى على خادم سبق إجراء unref عليه فلن يكون له أي تأثير.

الصنف net.Socket

أُضيف مع الإصدار: v0.3.4.

يعد هذا الصنف تجريد لمقبس TCP أو لنقطة نهاية دفق IPC (يستخدم الأنابيب المسماة في ويندوز، ومقابس مجال UNIX خلاف ذلك). وتعد net.Socket أيضا تيارًا مزدوجًا (duplex stream)، حيث يمكن أن تكون قابلة للقراءة والكتابة على حد سواء، وهي أيضا EventEmitter.

ويمكن للمستخدم إنشاء net.Socket واستخدامها مباشرة في التفاعل مع الخادم. على سبيل المثال، تُعاد من قِبل net.createConnection()‎، بحيث يمكن للمستخدم استخدامها للتحدث إلى الخادم.

ويمكن أيضا إنشاؤها بواسطة Node.js وتمريرها إلى المستخدم عند تلقي اتصال. على سبيل المثال، تُمرر إلى مستمعي الحدث 'connection' المُصدر على net.Server بحيث يمكن للمستخدم استخدامها للتفاعل مع العميل.

new net.Socket([options])‎

أُضيف مع الإصدار: v0.3.4.

إنشاء كائن مقبس جديد.

  • options من النوع <Object>: .الخيارات المتاحة هي:
    • fd من النوع <number>: وهو يغلف حول مقبس موجود مع واصف ملف معين، خلاف ذلك سيُنشَأ مقبس جديد.
    • allowHalfOpen من النوع <boolean>: وهو يشير إلى ما إذا كان مسموح باتصالات TCP مفتوحة نصفيا. راجع net.createServer()‎‎ والحدث 'end' لمزيد من التفاصيل. القيمة الافتراضية: false.
    • readable من النوع <boolean>: وهو يسمح بالقراءة على المقبس عند تمرير fd، ويُتجاهل بخلاف ذلك. القيمة الافتراضية: false.
    • writable من النوع <boolean>: ويسمح بالكتابة على المقبس عند تمرير fd، ويُتجاهل بخلاف ذلك. القيمة الافتراضية: false.
  • القيمة المُعادة: من النوع <net.Socket>.

يمكن أن يكون مأخذ التوصيل المُنشأ حديثا أما مقبس توصيل TCP أو نقطة نهاية IPC، اعتماداً على ما تتصل به من خلال connect()‎‎.

الحدث 'close'

أُضيف مع الإصدار: v0.1.90.

  • hadError من النوع <boolean>: وتكون قيمتها true إذا حدث للمقبس خطأ في النقل.

يُطلٓق حالما يغلق المقبس بالكامل. ويشير الوسيط hadError وهو قيمة منطقية إذا كان المقبس مغلقا بسبب خطأ في النقل.

الحدث 'connect'

أُضيف مع الإصدار: v0.1.90.

يطلق عند إتمام اتصال المقبس بنجاح. راجع net.createConnection()‎.

الحدث 'data'

أُضيف مع الإصدار: v0.1.90.

يُطلق عند استلام البيانات. وسيكون الوسيط data من النوع Buffer أو String. ويُضبط ترميز البيانات بواسطة socket.setEncoding()‎.

علما بأن data ستُفقَد إذا لم يكن هناك أي مستمع عندما يُطلِق Socket الحدث 'data'.

الحدث 'drain'

أُضيف مع الإصدار: v0.1.90.

يُطلق عندما يصبح مخزن الكتابة المؤقت فارغا. يمكن أن يستخدم لخنق التحميلات.

انظر أيضًا: القيم المعادة من socket.write()‎.

الحدث 'end'

أُضيف مع الإصدار: v0.1.90.

يطلق عندما يرسل الطرف الآخر من المقبس حزمة FIN، منهيًا بذلك الجانب المقروء من المقبس.

افتراضيًا (allowHalfOpen قيمتها false) سيرسل المقبس حزمة FIN مرة أخرى ويهدم واصف الملف تو كتابته أثناء وجوده في قائمة انتظار الكتابة. ومع ذلك، إذا ضُبطت allowHalfOpen بالقيمة true، لن ينهي المقبس تلقائيا جانب الكتابة الخاص به بواسطة التابعend()‎، مما يتيح للمستخدم كتابة كميات عشوائية من البيانات. يجب على المستخدم استدعاء end()‎ صراحةً لإغلاق الاتصال (أي إرسال حزمة FIN مرة أخرى).

الحدث 'error'

أُضيف مع الإصدار: v0.1.90.

يُطلَق عند حدوث خطأ ما. سيُستدعى الحدث 'close' مباشرة بعد هذا الحدث.

الحدث 'lookup'

سجل التغييرات

الإصدار التغييرات
v5.10.0 أصبح المعامل host مدعومًا الآن.
v0.11.3 أضيف مع الإصدار: v0.11.3.

يُطلَق بعد حل اسم المضيف ولكن قبل الاتصال. لا ينطبق على مقابس UNIX.

الحدث 'ready'

أُضيف مع الإصدار: v9.11.0.

يُطلَق عندما يكون مقبس ما على استعداد لاستخدامه.

ويُطلَق فورًا بعد الحدث 'connect'.

الحدث 'timeout'

أُضيف مع الإصدار: v0.1.90.

يُطلَق إذا انتهت مهلة المقبس نتيجة الخمول. و الغرض منه أن يخطر فقط أن المقبس خامل. يجب على المستخدم إغلاق الاتصال يدويًا.

انظر أيضًا: socket.setTimeout()‎.

socket.address()‎

أُضيف مع الإصدار: v0.1.90.

  • القيمة المُعادة: من النوع <Object>.

يعيد العنوان address المنضم واسم عائلة العنوان family ومنفذ الخادم port كما يذكره نظام التشغيل. { port: 12346, family: 'IPv4', address: '127.0.0.1' }

socket.bufferSize

أُضيفت مع الإصدار: v0.3.8.

من خواص net.Socket أن التابع socket.write()‎ دائما ما يعمل. وهذا لمساعدة المستخدمين للبدء والانطلاق بسرعة. لا يمكن لجهاز الكمبيوتر مواكبة كمية البيانات المكتوبة على المقبس دائماً، فقد يؤدي ببساطة إلى بطء شديد بشبكة الاتصال. وستصُف Node.js البيانات المكتوبة إلى المقبس داخليًا وترسلها عبر الأسلاك عندما يكون ذلك ممكناً. (فهي تختار واصف ملف المقبس داخليا لكونه قابل للكتابة).

وقد تتزايد الذاكرة نتيجة لهذا التخزين الداخلي المؤقت. وتبين هذه الخاصية عدد الأحرف المخزنة حاليا بغرض كتابتها. (عدد الأحرف مساو تقريبا للعدد البايتات المراد كتابتها، ولكن قد يحتوي المخزن المؤقت على سلاسل، والتي ترمَّز ببطء، لذلك لا يمكن معرفة عدد البايتات بالضبط).

يجب أن يحاول المستخدمون الذين يعانون من كِبر أو تزايد bufferSize "خنق" تدفق البيانات في برامجهم باستخدام socket.pause()‎ و socket.resume()‎.

socket.bytesRead

أضيفت مع الإصدار: v0.5.3.

مقدار وحدات البايت المُتلقاة.

socket.bytesWritten

أضيفت مع الإصدار: v0.5.3.

مقدار وحدات البايت المُرسَلة.

socket.connect()‎

بدء اتصال مقبس معين.

الأشكال الممكنة:

  • socket.connect(options[, connectListener])‎
  • socket.connect(path[, connectListener])‎ لاتصالات IPC.
  • socket.connect(port[, host][, connectListener])‎ لاتصالات TCP.
  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

هذه الدالة غير متزامنة. سيطلق الحدث 'connect' عند تأسيس الاتصال. إذا كان هناك مشكلة في الاتصال سيُطلق الحدث 'error' بدلا من الحدث 'connect' ويُمرر مع الخطأ إلى مستمع 'error'. سيضاف المعامل الأخير connectListener، إذا توفَّر، كمستمع للحدث 'connect' مرة واحدة.

socket.connect(options[, connectListener])‎

سجل التغييرات

الإصدار التغييرات
v6.0.0 أصبحت قيمة الخيار hints الافتراضية 0 في كافة الحالات الآن. في السابق، كانت قيمته الافتراضية DNS.ADDRCONFIG | dns.V4MAPPED. في حالة عدم وجود خيار family.
v5.11.0 أصبح الخيار  hints  مدعومًا الآن.
v0.1.90 أضيف مع الإصدار : v0.1.90.
  • options من النوع  <Object>.
  • connectListener من النوع <Function>: وهو معامل شائع لتوابع socket.connect()‎. سيضاف كمستمع للحدث 'connect' مرة واحدة.
  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

بدء الاتصال على مقبس معين. لا يستخدم هذا التابع عادةً، وينبغي إنشاء المقبس و فتحه باستخدام net.createConnection()‎. وينصح باستخدامه فقط عند تنفيذ مقبس مخصص.

الخيارات المتاحة لاتصالات TCP هي:

  • port من النوع <number>: وهو قيمة يجب إدخالها. وهو المنفذ الذي يجب على المقبس الاتصال به.
  • host من النوع <string>: وهو المضيف الذي يجب على المقبس الاتصال به. القيمة الافتراضية: 'localhost'.
  • localAddress من النوع <string>: وهو العنوان المحلي الذي يجب على المقبس الاتصال منه.
  • localPort من النوع <number>: وهو المنفذ محلي الذي يجب على المقبس الاتصال منه.
  • family من النوع<number>: نسخة من مُكدِّس IP، ويمكن أن تكون إما 4 أو 6. القيمة الافتراضية: 4.
  • hints من النوع <number>: وهي تلميحات اختيارية حول dns.lookup()‎.
  • lookup من النوع <Function> وهي دالة البحث المخصص. القيمة الافتراضية: dns.lookup()‎.

الخيارات المتاحة لاتصالات IPC هي:

  • path من النوع <string>: وهي قيمة يجب إدخالها. وهو المسار الذي يجب على العميل الاتصال به. راجع تحديد مسارات اتصالات IPC. وإذا توفرت، تُتَجاهَل خيارات TCP الخاصة المذكورة أعلاه.

socket.connect(path[, connectListener])‎

path من النوع <string>: وهو المسار الذي يجب على العميل الاتصال به. راجع تحديد مسارات اتصالات IPC.

connectListener من النوع <Function>: وهو معامل شائع لتوابع socket.connect()‎. سيضاف كمستمع للحدث 'connect' مرة واحدة.

  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

بدء اتصال IPC على المقبس المعطى.

اسم مستعار يشير إلى socket.connect(options[, connectListener])‎ ويستدعى مع الخيار options بالقيمة { path: path }.

socket.connect(port[, host][, connectListener])‎

أُضيف مع الإصدار: v0.1.90.

  • port من النوع <string>: وهو المنفذ الذي يجب على العميل الاتصال به.
  • host من النوع <string>:  وهو المضيف الذي يجب على العميل الاتصال به.
  • connectListener من النوع <Function> وهو معامل شائع لتوابع socket.connect()‎. سيضاف كمستمع للحدث 'connect' مرة واحدة.
  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

الشروع في اتصال TCP على المقبس المُعطى.

اسم مستعار يشير إلى socket.connect(options[, connectListener])‎ ويستدعى مع الخيار options بالقيمة {port: port, host: host}.

socket.connecting

أضيفت في: v6.1.0

إذا كان قيمتها true فهذا يعني استدعاء socket.connect(options[, connectListener])‎ وأنه لم ينته بعد. وتصبح قيمتها false قبل انبعاث الحدث 'connect' و/أو استدعاء دالة رد الاتصال socket.connect(options[, connectListener])‎.

socket.destroy([exception])‎

أُضيف مع الإصدار: v0.1.90.

  • exception من النوع <Object>.
  • القيمة المُعادة: من النوع <net.Socket>.

وهو يضمن عدم حدوث أي نشاط إدخال/إخراج على هذا المقبس. ويُعد ضروريا فقط في حالة الأخطاء (خطأ تحليل أو نحو ذلك).

إذا حُدِّد استثناءً exception، سيُطلق حدث 'error' وسيتلقى أي مستمع لهذا الحدث exception كوسيط.

socket.destroyed

من النوع <boolean>: ويشير إلى ما إذا كان الاتصال قد هُدِم أم لا. بمجرد هدم اتصال لا تُنقل أي بيانات باستخدامه.

socket.end([data][, encoding])‎

أُضيف مع الإصدار: v0.1.90.

  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

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

إذا كانت data مُحددة، فإن ذلك يكافئ استدعاء socket.write(data, encoding)‎ يتبعه socket.end()‎.

socket.localAddress

أضيفت مع الإصدار: v0.9.6.

وهو التمثيل النصي لعنوان IP المحلي الذي يتصل به العميل البعيد. على سبيل المثال، في خادم الاستماع إلى '0.0.0.0'، إذا اتصل عميل على '192.168.1.1'، ستتخذ socket.localAddress القيمة '192.168.1.1'.

socket.localPort

أضيفت مع الإصدار: v0.9.6.

التمثيل الرقمي للمنفذ المحلي. على سبيل المثال، 80 أو 21.

socket.pause()‎

  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

إيقاف مؤقت لقراءة البيانات. بمعنى عدم إطلاق الأحداث 'data'. وهو يفيد في خنق التحميل.

socket.ref()‎

أُضيف مع الإصدار: v0.9.1.

القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

على عكس unref()‎، استدعاء ref()‎ على خادم سبق إجراء unref عليه لن يسمح للبرنامج بالانتهاء إذا كان هو الخادم الوحيد المتبقي (السلوك الافتراضي). استدعاء ref()‎ مرة أخرى على مقبس سبق إجراء ref عليه لن يكون له أي تأثير.

socket.remoteAddress

أُضيف مع الإصدار: v0.5.10.

التمثيل النصي لعنوان IP البعيد. على سبيل المثال، '74.125.127.100' أو ‎'2001:4860:a005::68'‎. قد تكون القيمة غير معرفة undefined إذا هُدِم المقبس (على سبيل المثال، إذا قُطع اتصال العميل).

socket.remoteFamily

أُضيفت مع الإصدار: v0.11.14.

التمثيل النصي لعائلة IP البعيد. وتكون إما 'IPv4' أو 'IPv6'.

socket.remotePort

أُضيف مع الإصدار: v0.5.10.

التمثيل الرقمي للمنفذ البعيد. على سبيل المثال، 80 أو 21.

socket.resume()‎

  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

استئناف القراءة بعد استدعاء socket.pause()‎.

socket.setEncoding([encoding])‎

أُضيف مع الإصدار: v0.1.90.

  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

تعيين ترميز المقبس كدفق مقروء Readable Stream. راجع readable.setEncoding()‎ لمزيد من المعلومات.

socket.setKeepAlive([enable][, initialDelay])‎

أضيف مع الإصدار: v0.1.92.

  • enable من النوع <boolean>. القيمة الافتراضية: false.
  • initialDelay من النوع <number>. القيمة الافتراضية: 0.
  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

تمكين أو تعطيل وظيفة المحافظة على الحياة، وتعيين التأخير المبدئي قبل إرسال أول تحقق من المحافظة على الحياة (keepalive probe) على مقبس خامل.

ضبط initialDelay (بالمللي ثانية) لتعيين التأخير بين آخر حزمة بيانات واردة وأول تحقق من المحافظة على الحياة. وسيؤدي ضبط initialDelay بالقيمة 0 إلى ترك القيمة دون تغيير عن القيمة الافتراضية (أو القيمة السابقة).

socket.setNoDelay([noDelay])‎

أُضيف مع الإصدار: v0.1.90.

  • noDelay من النوع <boolean>. القيمة الافتراضية: true.
  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

تعطيل خوارزمية Nagle التي تستخدمها اتصالات TCP بشكل افتراضي، فتخزن البيانات مؤقتًا قبل إرسالها. ضبط noDelay بالقيمة true يُطلق البيانات فور استدعاء socket.write()‎.

socket.setTimeout(timeout[, callback])‎

أُضيف مع الإصدار: v0.1.90.

  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

ضبط المقبس للانقضاء بعد مهلة timeout من الخمول على المقبس محسوبًا بالمللي ثانية. بشكل افتراضي لا تملك net.Socket مهلة للانقضاء.

عند إطلاق مهلة خمول، يتلقى المقبس حدث 'timeout' ولكن لن ينقطع الاتصال. يجب على المستخدم استدعاء socket.end()‎ أو socket.destroy()‎ يدوياً لإنهاء الاتصال.

socket.setTimeout(3000);
socket.on('timeout', () => {
  console.log('socket timeout');
  socket.end();
});

إذا كانت timeout تساوي 0، تتعطل مهلة الخمول الحالية.

يضاف المعامل callback الاختياري كمستمع لمرة واحدة لحدث 'timeout'.

socket.unref()‎

أُضيف مع الإصدار: v0.9.1.

  • القيمة المُعادة: <net.Socket> وهو المقبس نفسه.

يسمح استدعاء unref()‎ على مقبسٍ ما للبرنامج بالإنهاء إذا كان هو المقبس النشط الوحيد في نظام الأحداث. استدعاء unref()‎ مرة أخرى على مقبس سبق إجراء unref عليه لن يكون له أي تأثير.

socket.write(data[, encoding][, callback])‎

أُضيف مع الإصدار: v0.1.90.

  • data من النوع ‎<string> | <Buffer> | <Uint8Array>‎.
  • encoding من النوع <string>: وتستخدم فقط عندما تكون data من النوع string. القيمة الافتراضية: utf8.
  • callback من النوع <Function>.
  • القيمة المُعادة: من النوع <boolean>.

إرسال البيانات على مقبس. ويحدد المعامل الثاني الترميز في حالة أن تكون البيانات سلسلة — ويكون الترميز UTF8 في الوضع الافتراضي.

ويعيد true إذا انتقلت البيانات بالكامل بنجاح إلى مخزن النواة المؤقت (kernel buffer). ويعيد false إذا كان كل أو جزء من البيانات في قائمة الانتظار في ذاكرة المستخدم. ويُطلق الحدث 'drain' عندما يكون المحزن المؤقت متاحًا مرة أخرى.

وسينفذ معامل رد الاتصال callback الاختياري عند الانتهاء من كتابة البيانات خارجًا--وقد لا حدث هذا فورًا.

راجع التابع write()‎ وهو تابع التيار القابل للكتابة Writable Stream‎ للحصول على مزيد من المعلومات.

net.connect()‎

الأسماء المستعارة للتابع net.createConnection()‎.

الأشكال الممكنة:

  • net.connect(options[, connectListener])‎
  • net.connect(path[, connectListener])‎ لاتصالات IPC.
  • net.connect(port[, host][, connectListener])‎ لاتصالات TCP.

net.connect(options[, connectListener])‎

أُضيف مع الإصدار: v0.7.0.

الاسم المستعار للتابع net.createConnection(options[, connectListener])‎.

net.connect(path[, connectListener])‎

أُضيف مع الإصدار: v0.1.90.

الاسم المستعار للتابع net.createConnection(path[, connectListener])‎.

net.connect(port[, host][, connectListener])‎

أُضيف مع الإصدار: v0.1.90.

الاسم المستعار للتابع net.createConnection(port[, host][, connectListener])‎.

net.createConnection()‎

وهي دالة تصنيع، تنشئ net.Socket جديدة، وهي تهيئ اتصال مع socket.connect()‎، ثم تعيد net.Socket الذي يبدأ الاتصال.

عند تأسيس الاتصال، سيُطلق الحدث 'connect' على المقبس المُعاد. وسيضاف المعامل الأخير connectListener، إذا توفَّر، كمستمع للحدث 'connect' مرة واحدة.

الأشكال الممكنة:

  • net.createConnection(options[, connectListener])‎
  • net.createConnection(path[, connectListener])‎ لاتصالات IPC.
  • net.createConnection(port[, host][, connectListener])‎ لاتصالات TCP.

الدالة net.connect()‎ هي اسم مستعار لهذه الدالة.

net.createConnection(options[, connectListener])‎

أُضيف مع الإصدار: v0.1.90.

  • options من النوع <Object>: ويجب إدخالها. ستمرر إلى كل من استدعاء new net.Socket([options])‎ والتابع socket.connect(options[, connectListener])‎.
  • connectListener من النوع <Function>: وهو معامل شائع للدالة net.createConnection()‎. إذا توفَّرت، ستضاف كمستمع للحدث 'connect' على المقبس المُعاد مرة واحدة.
  • القيمة المُعادة: <net.Socket> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.

للخيارات المتاحة، انظر new net.Socket([options])‎ و socket.connect(options[, connectListener]).

خيارات إضافية:

  • timeout من النوع <number>: إذا ضُبِط، سيستخدم لاستدعاء socket.setTimeout(timeout)‎ بعد إنشاء مقبس، ولكن قبل أن يبدأ الاتصال.

فيما يلي مثال لعميل خادم صدى (echo server) الموصوف في قسم ()‎‎net.createServer:

const net = require('net');
const client = net.createConnection({ port: 8124 }, () => {
  // 'connect' مستمع
  console.log('التوصيل مع الخادم!');
  client.write('أيها العالم!\r\n');
});
client.on('data', (data) => {
  console.log(data.toString());
  client.end();
});
client.on('end', () => {
  console.log('قطع الإتصال مع الخادم');
});

للاتصال على المقبس ‎/tmp/echo.sock يجب تغيير السطر الثاني فقط إلى:

const client = net.createConnection({ path: '/tmp/echo.sock' });

net.createConnection(path[, connectListener])‎

أُضيف مع الإصدار: v0.1.90.

  • path من النوع <string>: وهو المسار الذي يجب على المقبس الاتصال به. سيُمرر إلى socket.connect(path[, connectListener])‎. راجع تحديد مسارات اتصالات IPC.
  • connectListener من النوع <Function>: وهو معامل شائع لدوال net.createConnection()‎ وهو مستمع "لمرة واحدة" للحدث 'connect' المقبس البادئ. سيُمرر إلى socket.connect(path[, connectListener])‎.
  • القيمة المُعادة: <net.Socket> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.

يبدأ إجراء اتصال IPC.

تُنشئ هذه الدالة net.Socket مع جميع الخيارات مضبوطة بالقيم الافتراضية، وتبدأ الاتصال مع socket.connect(path[, connectListener])‎ على الفور، ثم تعيد net.Socket والذي يبدأ الاتصال.

net.createConnection(port[, host][, connectListener])‎

أُضيف مع الإصدار: v0.1.90.

  • port من النوع <number>: وهو المنفذ الذي يجب على المقبس الاتصال به. سيُمرر إلى socket.connect(port[, host][, connectListener])‎.
  • host من النوع <string>: وهو المضيف الذي الذي يجب على المقبس الاتصال به. سيُمرر إلى socket.connect(port[, host][, connectListener])‎. القيمة الافتراضية: 'localhost'.
  • connectListener من النوع <Function>: وهو معامل شائع لدوال net.createConnection()‎ وهو مستمع "لمرة واحدة" للحدث 'connect' المقبس البادئ. سيُمرر إلى socket.connect(path[, connectListener])‎.
  • القيمة المُعادة: <net.Socket> وهو المقبس المُنشأ حديثا والمستخدم لبدء الاتصال.

يبدأ اتصال TCP.

تُنشئ هذه الدالة net.Socket مع جميع الخيارات مضبوطة بالقيم الافتراضية، وتبدأ الاتصال مع socket.connect(port[, host][, connectListener])‎ على الفور، ثم تعيد net.Socket والذي يبدأ الاتصال.

net.createServer([options][, connectionListener])‎

أُضيف مع الإصدار: v0.5.0.

إنشاء خادم TCP أو IPC جديد.

  • options من النوع  <Object>.
  • allowHalfOpen من النوع <boolean>: وهو يشير إلى ما إذا كان مسموح باتصالات TCP مفتوحة نصفيا. القيمة الافتراضية: false.
  • pauseOnConnect من النوع <boolean>: وهو يحدد ما إذا كان يجب إيقاف المقبس مؤقتا عن الاتصالات الواردة .القيمة الافتراضية: false.
  • connectionListener من النوع <Function>: وهو يضبط مستمع للحدث 'connection' تلقائيا.
  • القيمة المُعادة: من النوع <net.Server>.

إذا ضُبط allowHalfOpen بالقيمة true عندما يرسل الطرف الآخر من المقبس حزمة FIN، يرسل الخادم حزمة FIN فقط عند استدعاء socket.end()‎ صراحة وحتى هذا الحين يكون الاتصال مغلقًا نصفيًا (غير مقروء ولكن لا يزال قابل للكتابة). انظر الحدث 'end' و RFC 1122 (القسم 4.2.2.13) لمزيد من المعلومات.

إذا ضُبط pauseOnConnect بالقيمة true، سيتوقف المقبس المرتبط مع كل اتصال وارد مؤقتا، ولن تُقرأ أي بيانات من معالجها. ويسمح هذا للاتصالات بالمرور بين العمليات دون قراءة أي بيانات من قِبَل العملية الأصلية. للبدء في قراءة البيانات من مقبس متوقف مؤقتاً، يجب استدعاء socket.resume()‎.

يمكن أن يكون الخادم TCP أو IPC اعتماداً على ما يستمع إليه بواسطة listen()‎.

إليك مثال على صدى خادم TCP والذي يستمع للاتصالات على المنفذ 8124:

const net = require('net');
const server = net.createServer((c) => {
  // 'connection' مستمع
  console.log('إتصال العميل');
  c.on('end', () => {
    console.log('قطع إتصال العميل');
  });
  c.write('مرحبًا\r\n');
  c.pipe(c);
});
server.on('error', (err) => {
  throw err;
});
server.listen(8124, () => {
  console.log('الخادم مرتبط');
});

اختبر هذا باستخدام telnet:

$ telnet localhost 8124

للاستماع على المقبس ‎/tmp/echo.sock يجب تغيير السطر الثالث من النهاية فقط إلى:

server.listen('/tmp/echo.sock', () => {
  console.log('الخادم مرتبط');
});

ويستخدم nc للاتصال بخادم مقبس مجال UNIX:

$ nc -U /tmp/echo.sock

net.isIP(input)‎

أُضيف مع الإصدار: v0.3.0.

  • القيمة المُعادة: من النوع <integer>.

تُعيد الاختبارات إذا كان المُدخَل عنوان IP القيمة 0 للسلاسل النصية غير الصالحة، و 4 لعناوين IP من الإصدار 4 و 6 لعناوين IP من الإصدار 6.

net.isIPv4(input)‎

أُضيف مع الإصدار: v0.3.0.

  • القيمة المُعادة: من النوع <boolean>

تُعيد true في حالة إدخال عنوان IP من الإصدار 4، وإلا سيُعيد false.

net.isIPv6(input)‎

أُضيف مع الإصدار: v0.3.0.

  • القيمة المُعادة: من النوع <boolean>.

تُعيد true في حالة إدخال عنوان IP من الإصدار 6، وإلا سيُعيد false.

مصادر