SharePoint - क्लाइंट ऑब्जेक्ट मॉडल

इस अध्याय में, हम क्लाइंट ऑब्जेक्ट मॉडल या CSOM पर एक नज़र डालेंगे। SharePoint 2010 में जोड़े गए दूरस्थ अनुप्रयोगों के निर्माण के लिए, यह दो API में से एक था।

क्लाइंट ऑब्जेक्ट मॉडल के डिजाइन लक्ष्यों में से एक सर्वर ऑब्जेक्ट मॉडल की यथासंभव नकल करना था, इसलिए डेवलपर्स के लिए एक छोटा सीखने की अवस्था होगी जो पहले से ही सर्वर साइड पर विकास करने से परिचित है।

क्लाइंट ऑब्जेक्ट मॉडल का दिल Client.svc नामक एक वेब सेवा है, जिसमें रहता है _vti_binआभासी निर्देशिका। हमें Client.svc के साथ सीधे संवाद नहीं करना चाहिए, लेकिन हमें तीन प्रॉक्सी या प्रवेश बिंदु दिए गए हैं, जिनका हम उपयोग कर सकते हैं। वे हैं -

  • .NET प्रबंधित कोड।
  • JavaScript.
  • JavaScript.

कोड इन प्रॉक्सी के साथ संचार करता है और फिर ये प्रॉक्सी वेब सेवा के साथ संचार करता है।

चूंकि यह एक दूरस्थ एपीआई है और संचार वेब सेवा कॉल के माध्यम से SharePoint के साथ किया जाता है, क्लाइंट ऑब्जेक्ट मॉडल हमें सूचनाओं के लिए आदेशों और अनुरोधों को बैचने की अनुमति देने के लिए डिज़ाइन किया गया है।

.NET प्रबंधित कोड

.NET प्रबंधित कार्यान्वयन के लिए दो मुख्य असेंबली हैं -

Microsoft.SharePoint.Client.dll तथा Microsoft.SharePoint.Client.Runtime.dll.

चाँदी का कूट

सिल्वरलाइट कार्यान्वयन के लिए विधानसभाएं रहती हैं TEMPLATE\LAYOUTS\ClientBin। विधानसभा के नाम भी से शुरू होते हैंMicrosoft.SharePoint.Client। सभी विधानसभाओं के लिए लेकिन एक, विधानसभा का नाम सिल्वरलाइट में समाप्त होता है।

सिल्वरलाइट कार्यान्वयन के लिए दो मुख्य विधानसभाएं हैं -

  • Microsoft.SharePoint.Client.Silverlight.dll
  • Microsoft.SharePoint.Client.Silverlight.Runtime.dll

जावास्क्रिप्ट

क्लाइंट ऑब्जेक्ट मॉडल पर जावास्क्रिप्ट कार्यान्वयन SharePoint सिस्टम रूट के नीचे TEMPLATE \ LAYOUTS फ़ोल्डर में रहता है। जावास्क्रिप्ट लाइब्रेरी के नाम सभी एसपी से शुरू होते हैं। तीन मुख्य पुस्तकालय हैंSP.js, Sp.Runtime.js, तथा SP.Core.js

क्लाइंट ऑब्जेक्ट मॉडल का विस्तार SharePoint 2013 में किया गया है।

.NET का उपयोग कर लोड के साथ संसाधन पुनर्प्राप्त करें

आइए एक सरल उदाहरण देखें जिसमें हम विंडोज फॉर्म एप्लिकेशन का उपयोग करके क्लाइंट ऑब्जेक्ट मॉडल के प्रबंधित कार्यान्वयन का उपयोग करेंगे। इसलिए, पहले हमें एक नई परियोजना बनाने की आवश्यकता है।

Step 1 - चयन करें Windows Forms Applicationमध्य फलक में और नाम फ़ील्ड में नाम दर्ज करें। ओके पर क्लिक करें।

Step 2- प्रोजेक्ट बन जाने के बाद, नीचे दिखाए गए अनुसार एक सूची बॉक्स और एक बटन जोड़ें। क्लाइंट ऑब्जेक्ट मॉडल का उपयोग करने के लिए, हमें कुछ विधानसभा संदर्भों को जोड़ना होगा। संदर्भ पर राइट-क्लिक करें और संदर्भ जोड़ें चुनें।

Step 3 - चयन करें Extensions के तहत बाएँ फलक में Assemblies

क्लाइंट ऑब्जेक्ट मॉडल के प्रबंधित कार्यान्वयन के लिए दो मुख्य असेंबली हैं Microsoft.SharePoint.Client तथा Microsoft.SharePoint.Client.Runtime। इन दो विकल्पों की जाँच करें और ठीक पर क्लिक करें।

अब नीचे दिए गए इवेंट हैंडलर को जोड़ने के लिए लोड बटन पर डबल क्लिक करें।

using Microsoft.SharePoint.Client;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace ClientObjectModel {
   public partial class Form1 : Microsoft.SharePoint.Client.Form {
      public Form1() {
         InitializeComponent();
      }
      private void loadBtn_Click(object sender, EventArgs e) {
         using (var context = new ClientContext("http://waqasserver/sites/demo")) {
            var web = context.Web;
            context.Load(web);
            context.Load(web.Lists);
            context.ExecuteQuery();
            ResultListBox.Items.Add(web.Title);
            ResultListBox.Items.Add(web.Lists.Count);
         }
      }
   }
}

क्लाइंट ऑब्जेक्ट मॉडल में प्रवेश बिंदु क्लाइंट संदर्भ है। यह क्लाइंट वर्जन का रिमोट हैSPContextवस्तु। यह एक डिस्पोजेबल प्रकार है, इसलिए इसे एक में लपेटा जाता हैusingबयान। हम URL को SharePoint साइट में पास करते हैंClientContext

तो अब, हम अपने संदर्भ है। हमें वर्तमान साइट का प्रतिनिधित्व करने के लिए एक ऑब्जेक्ट की आवश्यकता है ताकि वह होvar web = context.web

Note- याद रखें, यह ऑब्जेक्ट केवल एक खाली शेल है, इसलिए हमें संदर्भ ऑब्जेक्ट को उपयोग करके वेब ऑब्जेक्ट को लोड करना होगा और वेब ऑब्जेक्ट को पास करना होगा। यह इंगित करता है कि हम चाहते हैं कि वेब ऑब्जेक्ट्स गुण अगले बैच पुनर्प्राप्ति में आबादी वाले हों।

अगला, हमें कॉल करने की आवश्यकता है context.ExecuteQueryऔर जो वास्तव में बैच पुनर्प्राप्ति को मारता है। हम सर्वर से संपत्ति मूल्यों को पुनः प्राप्त करते हैं और सूची बॉक्स में जोड़ते हैं।

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप निम्न आउटपुट देखेंगे -

लोड बटन पर क्लिक करें और आप देखेंगे कि हमें सूचियों का शीर्षक और गिनती दोनों मिलेंगे।

यह लोड विधि का उपयोग करके लोडिंग संसाधनों की जांच करने के लिए क्लाइंट ऑब्जेक्ट मॉडल का उपयोग करने के लिए हमारे प्रोजेक्ट सेटअप को सक्षम करता है।