डब्ल्यूसीएफ - सर्विस बाइंडिंग

WCF सर्विस बाइंडिंग कई तत्वों का एक सेट है जिसमें प्रत्येक तत्व क्लाइंट के साथ सेवा के संचार के तरीके को परिभाषित करता है। एक परिवहन तत्व और एक संदेश एन्कोडिंग तत्व प्रत्येक बंधन के दो सबसे महत्वपूर्ण घटक हैं। इस अध्याय में, हम विभिन्न डब्ल्यूसीएफ सेवा बाइंडिंग पर चर्चा करेंगे जो आमतौर पर उपयोग की जाती हैं।

बुनियादी बंधन

BasicHttpBinding वर्ग द्वारा बेसिक बाइंडिंग की पेशकश की जाती है। यह एक ASP.NET वेब सेवा (ASMX वेब सेवा) के रूप में WCF सेवा को परिवहन और प्रतिनिधित्व करने के लिए HTTP प्रोटोकॉल का उपयोग करता है, ताकि ASMX वेब सेवाओं का उपयोग करने वाले पुराने ग्राहक नई सेवाओं का आसानी से उपभोग कर सकें।

मूल बंधन को सिल्वरलाइट द्वारा सक्षम WCF वेब सेवा में डिफ़ॉल्ट बाइंडिंग के रूप में सेट किया गया है और यह वेब सेवा शैली में संचार के लिए एक मानक बाइंडिंग है। यह विश्वसनीय मैसेजिंग का समर्थन नहीं करता है।

नीचे दिया गया एक कोड स्निपेट है जो मूल बाइंडिंग के लिए डिफ़ॉल्ट सेटिंग्स को दर्शाता है।

<basicHttpBinding>
   <binding name = "basicHttpBindingDefaults" allowCookies = "false" 
      bypassProxyOnLocal = "false" hostNameComparisonMode = "StrongWildcard" 
      maxBufferPoolSize = "524288" maxBufferSize = "65536" 
      maxReceivedMessageSize = "65536" messageEncoding = "Text" proxyAddress = "" 
      textEncoding = "utf-8" transferMode = "Buffer" useDefaultWebProxy = "true" 
      closeTimeout = "00:01:00" openTimeout = "00:01:00" receiveTimeout = "00:10:00" 
      sendTimeout = "00:01:00">
   
      <readerQuotas maxArrayLength = "16384" maxBytesPerRead = "4096" 
         maxDepth = "32"
         maxNameTableCharCount = "16384" maxStringContentLength = "8192"/>

      <security mode = "None">
         <transport clientCredentialType = "None" proxyCredentialType = "None" realm = ""/>
         <message algorithmSuite = "Basic256" clientCredentialType = "UserName" />
      </security>       
   </binding>

</basicHttpBinding>

उपरोक्त डिफ़ॉल्ट सेटिंग्स की अपनी स्पष्ट सीमाएँ हैं, क्योंकि संदेश का आकार सीमित है और कोई सुरक्षा मोड नहीं है। हालाँकि, बेसिक बाइंडिंग का अनुकूलन इस समस्या को हल करता है जैसे नीचे।

<basicHttpBinding>
   <binding name = "basicHttpSecure" maxBufferSize = "100000" maxReceivedMessageSize = "100000">
   
      <readerQuotas maxArrayLength = "100000" maxStringContentLength = "100000"/>
      <security mode = "TransportWithMessageCredential" />
     
   </binding>
</basicHttpBinding>

वेब सेवा बंधन

WSHttpBinding वर्ग द्वारा वेब सेवा (WS) बाइंडिंग प्रदान की जाती है। यह बुनियादी बाध्यकारी के समान है और परिवहन के लिए समान प्रोटोकॉल का उपयोग करता है, लेकिन WS- विश्वसनीय संदेश, WS- लेनदेन, WS- सुरक्षा और कई और अधिक जैसे कई WS- * विनिर्देशों प्रदान करता है। संक्षेप में, WSHttpBinding बेसिकहेटबाइंडिंग और WS- * विनिर्देशों के योग के बराबर है। नीचे दिए गए एक कोड स्निपेट है जो WS बाइंडिंग के लिए डिफ़ॉल्ट सेटिंग्स को दर्शा रहा है -

<wsHttpBinding>
   <binding name = "wsHttpBindingDefaults" allowCookies = "false" 
      bypassProxyOnLocal = "false" closeTimeout = "00:01:00" 
      hostNameComparisonMode = "StrongWildcard" 
      maxBufferPoolSize = "524288" maxReceivedMessageSize = "65536" 
      messageEncoding = "Text" openTimeout = "00:01:00" 
      receiveTimeout = "00:10:00" proxyAddress = "" sendTimeout = "00:01:00" 
      textEncoding = "utf-8" transactionFlow = "false" 
      useDefaultWebProxy = "true" > 
   
      <readerQuotas maxArrayLength = "16384" maxBytesPerRead = ."4096" 
         maxDepth = "32" maxNameTableCharCount = "16384" 
         maxStringContentLength = "8192"/>

      <reliableSession enabled = "false" ordered = "true" 
         inactivityTimeout = "oo:10:00" /> 

      <security mode = "Message">
         <message algorithmSuite = "Basic256" clientCredentialType = "Windows" 
            esatalishSecurityContext = "true" 
            negotiateServiceCredential = "true" />

         <transport clientCredentialType = "Windows"
            proxyCredentialType = "None" realm = ""/>        	
      </security>
      
   </binding>
</wsHttpBinding>

IPC बाइंडिंग

IPC बाइंडिंग नामित पाइप का उपयोग करता है और netNamedPipeBinding वर्ग द्वारा प्रस्तुत किया जाता है। सभी उपलब्ध बाइंडिंग के बीच यह सबसे तेज़ बाइंडिंग और सबसे सुरक्षित है। यद्यपि यहां संदेश-स्तरीय सुरक्षा का समर्थन नहीं किया गया है, लेकिन मजबूत परिवहन सुरक्षा के कारण संदेश डिफ़ॉल्ट रूप से सुरक्षित हैं। नीचे दिए गए कोड स्निपेट IPC बाइंडिंग के लिए डिफ़ॉल्ट सेटिंग्स को दर्शाते हैं -

<netNamedPipeBinding>
   
   <binding name = "netPipeDefaults" closeTimeout = "00:01:00" 
      hostNameComparisonMode = "StrongWildcard" maxBufferPoolSize = "524288" 
      maxBufferSize = "65536" maxConnections = "10" 
      maxReceivedMessageSize = "65536" openTimeout = "00:01:00" 
      receiveTimeout = "00:10:00" sendTimeout = "00:01:00" transactionFlow = "false" 
      transactionProtocol = "OleTransactions" transferMode = "Buffered">  

      <readerQuotas maxArrayLength = "16384" maxBytesPerRead = "4096" 
         maxDepth = "32" maxNameTableCharCount = "16384" 
         maxStringContentLength = "8192"/>
   
      <security mode = "Transport">        	
      </security>
      
   </binding>
</netNamedPipeBinding>

अन्य प्रकार की सेवा बाइंडिंग

  • TCP Binding- NetTCPBinding वर्ग द्वारा प्रदान किया गया, यह बंधन एक ही नेटवर्क के भीतर संचार के लिए टीसीपी प्रोटोकॉल का उपयोग करता है और संदेश को द्विआधारी प्रारूप में एन्कोडिंग करता है। इस बंधन को दूसरों के विपरीत सबसे विश्वसनीय माना जाता है।

  • WS Dual Binding- इस प्रकार का बाइंडिंग केवल अपवाद के साथ WSHttpBinding की तरह अधिक है कि यह द्विदिश संचार की सुविधा देता है, अर्थात, संदेश क्लाइंट और सेवाओं दोनों द्वारा भेजे और प्राप्त किए जा सकते हैं। यह WSDualHttpBinding वर्ग द्वारा की पेशकश की है।

  • Web binding - वेब बाइंडिंग को HTTP-GET, HTTP-POST, इत्यादि के द्वारा HTTP अनुरोधों के रूप में WCF सेवाओं का प्रतिनिधित्व करने के लिए डिज़ाइन किया गया है। यह WebHttpBinding वर्ग द्वारा प्रस्तुत किया गया है और इसका उपयोग आमतौर पर सोशल नेटवर्क के साथ किया जाता है।

  • MSMQ Binding- यह नेटमैस्क्बाइंडिंग क्लास द्वारा पेश किया जाता है और क्लाइंट द्वारा भेजे गए संदेश की तुलना में सेवा को एक अलग समय पर संदेश संसाधित करने के मामले में समाधान प्रदान करने के लिए उपयोग किया जाता है। MSMQ बाइंडिंग परिवहन के लिए MSMQ का उपयोग करता है और अलग किए गए संदेश कतारबद्ध को समर्थन प्रदान करता है। MSMQ Microsoft द्वारा दी जाने वाली संदेश कतार के लिए एक कार्यान्वयन है।

  • Federated WS Binding- यह डब्लूएस बाइंडिंग का एक विशिष्ट रूप है और फेडरेटेड सुरक्षा के लिए समर्थन प्रदान करता है। यह WSFederationHttpBinding वर्ग द्वारा की पेशकश की है।

  • Peer Network Binding- NetPeerTCPBinding वर्ग द्वारा पेश किया गया, यह मुख्य रूप से फाइल शेयरिंग सिस्टम में उपयोग किया जाता है। यह टीसीपी प्रोटोकॉल का उपयोग करता है लेकिन परिवहन के रूप में सहकर्मी नेटवर्किंग का उपयोग करता है। इस नेटवर्किंग में, प्रत्येक मशीन (नोड) अन्य नोड्स के लिए एक क्लाइंट और सर्वर के रूप में कार्य करता है। पीयर नेटवर्क बाइंडिंग का उपयोग टोरेंट जैसे फाइल शेयरिंग सिस्टम में किया जाता है।

  • MSMQ Integration Binding - MsmqIntegrationBinding वर्ग द्वारा प्रस्तुत, यह मौजूदा सिस्टम के साथ संचार करने में मदद करता है जो MSMQ (Microsoft संदेश कतार) के माध्यम से संचार करते हैं।

इनके अलावा, कस्टम बाइंडिंग बनाना भी संभव है। हालांकि, चूंकि प्रत्येक डब्ल्यूसीएफ बंधन के कॉन्फ़िगरेशन गुणों को मोड़ना संभव है, कस्टम बाइंडिंग बनाने की आवश्यकता शायद ही कभी उठती है।