SharePoint - सर्वर ऑब्जेक्ट मॉडल

इस अध्याय में, हम SharePoint Server ऑब्जेक्ट मॉडल पर एक नज़र डालेंगे। आप SharePoint सर्वर ऑब्जेक्ट मॉडल का उपयोग करते हैं जब आप कोड लिख रहे होते हैं जो SharePoint के संदर्भ में चलेगा। कुछ सामान्य उदाहरण एक पृष्ठ या एक वेब भाग में कोड-पीछे, एक सुविधा या एक सूची, टाइमर नौकरियों आदि के पीछे घटना संचालकों होंगे।

सर्वर ऑब्जेक्ट मॉडल की विशेषताएं

सर्वर ऑब्जेक्ट मॉडल की प्रमुख विशेषताएं निम्नलिखित हैं

  • आप सर्वर ऑब्जेक्ट मॉडल का उपयोग कर सकते हैं यदि आप उसी अनुप्रयोग पूल के अंदर ASP.NET अनुप्रयोग प्रोग्रामिंग कर रहे हैं जो SharePoint द्वारा उपयोग किया जाता है।

  • सर्वर ऑब्जेक्ट मॉडल का उपयोग किया जा सकता है यदि आप क्लाइंट एप्लिकेशन जैसे कंसोल या विंडोज फॉर्म या एक WPF ऐप विकसित कर रहे हैं जो SharePoint सर्वर पर चलेगा।

  • आप SharePoint सर्वर से दूरस्थ रूप से कनेक्ट करने के लिए सर्वर ऑब्जेक्ट मॉडल का उपयोग नहीं कर सकते।

  • जब आप सर्वर ऑब्जेक्ट मॉडल का उपयोग करना चाहते हैं, तो आप को देखें Microsoft.SharePointसभा। अन्य विधानसभाएं हैं, जो सर्वर ऑब्जेक्ट मॉडल बनाती हैं, लेकिन Microsoft.SharePoint मुख्य है।

  • मुख्य प्रकार जिनका उपयोग आप आमतौर पर उन घटकों के लिए करते हैं, जिन्हें आप अंतिम उपयोगकर्ता के रूप में उपयोग करते हैं, इसलिए साइट संग्रह, साइट, सूची, लाइब्रेरी और सूची आइटम जैसी चीजें SPSite, SPWeb, SPList, SPDDmentLibrary और SPListItem।

  • प्रकार और सर्वर ऑब्जेक्ट मॉडल जो साइट संग्रह का प्रतिनिधित्व करता है, वह SPSite है और सर्वर ऑब्जेक्ट मॉडल में SharePoint साइट का प्रतिनिधित्व करने वाला प्रकार SPWeb है। इसलिए, जब आप अंतिम उपयोगकर्ता की शर्तों से डेवलपर शर्तों पर जाते हैं, तो आपको बस उस मानसिक मानचित्रण को करना होगा।

अब जब आप पहली बार SharePoint का उपयोग करना शुरू करते हैं, तो यह भ्रामक हो सकता है क्योंकि साइट बहुत अधिक भरी हुई है और इसका मतलब है कि अंत उपयोगकर्ता और डेवलपर शब्दसंग्रह में विपरीत बातें, वेब शब्दावली का उल्लेख नहीं करना।

आइए हम सर्वर ऑब्जेक्ट मॉडल के एक सरल उदाहरण पर एक नज़र डालते हैं।

Step 1 - विजुअल स्टूडियो खोलें और से एक नया प्रोजेक्ट बनाएं File → New → Project मेनू विकल्प।

Step 2 - से विंडोज का चयन करें Templates → Visual C#बाएं फलक में और मध्य फलक में कंसोल एप्लिकेशन चुनें। अपने प्रोजेक्ट का नाम दर्ज करें और ओके पर क्लिक करें।

Step 3 - प्रोजेक्ट बन जाने के बाद, सोल्यूशन एक्सप्लोरर में प्रोजेक्ट को राइट-क्लिक करें और चुनें Add → References

Step 4 - चयन करें Assemblies → Extensions बाएँ फलक में और Microsoft.SharePoint को मध्य फलक में जाँचें और Ok बटन पर क्लिक करें।

अब समाधान एक्सप्लोरर में प्रोजेक्ट पर फिर से राइट-क्लिक करें और गुण चुनें।

Step 5 - क्लिक करें Build बाएँ फलक में टैब और अनचेक करें Prefer 32-bit विकल्प।

Step 6 - अब वापस जाएं Program.cs फ़ाइल और इसे निम्न कोड से बदलें।

using Microsoft.SharePoint;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace SharePointData {
   class Program {
      static void Main(string[] args) {
         using (var site = new SPSite("http://waqasserver/sites/demo")) {
            var web = site.RootWeb;
            Console.WriteLine(web.Title);
            var lists = web.Lists;
            
            foreach (SPList list in lists) {
               Console.WriteLine("\t" + list.Title);
            }
            Console.ReadLine();
         }
      }
   }
}

Note- उपरोक्त कोड में पहली बार एक नया SPSite ऑब्जेक्ट बनाया गया। यह एक डिस्पोजेबल ऑब्जेक्ट है, इसलिए इसे एक उपयोग स्टेटमेंट के भीतर बनाया गया है। SPSite कंस्ट्रक्टर URL को साइट संग्रह में ले जाता है, जो आपके मामले में अलग होगा।

संस्करण web = site.RootWeb साइट संग्रह की जड़ मिल जाएगा।

हम web.Lists का उपयोग करके सूचियों को प्राप्त कर सकते हैं और सूची आइटम के शीर्षक को प्रिंट कर सकते हैं।

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

SharePoint Tutorials
   appdata
   Authors
   Composed Looks
   Contacts
   Course Documents
   Courses
   Documents
   List Template Gallery
   Master Page Gallery
   Site Assets
   Site Pages
   Solution Gallery
   Style Library
   Theme Gallery
   User Information List
   Web Part Gallery

आप देख सकते हैं कि ये टाइटल सॉल्यूशन गैलरी, स्टाइल लाइब्रेरी, फॉर्म टेम्प्लेट हैं। ये ऐसी सूचियाँ हैं जिनका उपयोग SharePoint द्वारा आंतरिक रूप से किया जाता है। इसलिए, सभी सूचियों को प्रदर्शित करने के बजाय, शायद आप केवल उन सूचियों को दिखाना चाहते हैं जो उपयोगकर्ता सामान्य रूप से देखेंगे।

इसलिए, संपूर्ण सूची संग्रह प्राप्त करने के बजाय, हम उन सभी सूचियों को प्राप्त करना चाहते हैं जो छिपी नहीं हैं। हम नीचे दिए गए अनुसार लिंक क्वेरी का उपयोग कर सकते हैं।

using Microsoft.SharePoint;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ServerObjectModel {
   class Program {
      static void Main(string[] args) {
         using (var site = new SPSite("http://waqasserver/sites/demo")) {
            var web = site.RootWeb;
            Console.WriteLine(web.Title);
            var lists = from SPList list in web.Lists
            where list.Hidden == false
            select list;
            
            foreach (SPList list in lists) {
               Console.WriteLine("\t" + list.Title);
            }
            Console.ReadLine();
         }
      }
   }
}

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

SharePoint Tutorials
   Authors
   Contacts
   Course Documents
   Courses
   Documents
   Site Assets
   Site Pages
   Style Library

आप देख सकते हैं कि यह हमें उन सभी सूचियों को वापस देगा जो छिपी नहीं हैं।

आइए हम एक और सरल उदाहरण देखें जिसमें हम सूची वस्तुओं के बारे में कुछ जानकारी भी प्रदर्शित करेंगे।

using Microsoft.SharePoint;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ServerObjectModel {
   class Program {
      static void Main(string[] args) {
         using (var site = new SPSite("http://waqasserver/sites/demo")) {
            var web = site.RootWeb;
            Console.WriteLine(web.Title);
            var lists = from SPList list in web.Lists
            where list.Hidden == false
            select list;
            
            foreach (SPList list in lists) {
               Console.WriteLine("\t" + list.Title);
               var items = list.Items.OfType<SPListItem>().Take(5);
               var isDocLib = list is SPDocumentLibrary;
               
               foreach (SPListItem item in items) {
                  var value = isDocLib ? item.Name : item.Title;
                  Console.WriteLine("\t\t" + value);
               }
            }
            Console.ReadLine();
         }
      }
   }
}

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

SharePoint Tutorials
   Authors
      Muhammad Waqas
      Mark Upston
      Allan Bommer
      Andy Onian
   Contacts
      Waqas
      Upston
      Bommer
   Course Documents
      Sample1.docx
      Sample2.docx
      Sample3.docx
   Courses
      SharePoint Tutorials
      C# Tutorials
      ASP.Net Tutorials
      NHibernate Tutorials
   Documents
   Site Assets
   Site Pages
      Home.aspx
      How To Use This Library.aspx
   Style Library

सूची डेटा

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

चूंकि, हर सूची एक कॉलम से शुरू होती है- शीर्षक, द SPListItemप्रकार एक संपत्ति के रूप में उजागर करता है। उन स्तंभों के लिए जो प्रत्येक एकल सूची के लिए सामान्य नहीं हैं, आप उन्हें अनुक्रमणिका के माध्यम से एक्सेस कर सकते हैंSpListItem प्रकार।

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

दूसरा है InternalName, जो इस सूची में बनाया गया है और यह कभी नहीं बदलता है। यह वह नाम है जिसका उपयोग आप तब करना चाहते हैं जब आप स्तंभ मान पर पहुँच रहे हैं।

आइए हम एक सरल उदाहरण देखें जिसमें हम नीचे दिखाए अनुसार लेखकों की सूची पुनः प्राप्त करेंगे -

इस उदाहरण में, हम लेखकों की सूची प्राप्त करेंगे और फिर कुछ मूल्य से वेतन / दर बढ़ाएँगे। इसलिए, वेतन / दर कॉलम के लिए हम इसका उपयोग करेंगेInternalName

Step 1- सर्वर एक्सप्लोरर पर जाएं; दाएँ क्लिक करेंSharePoint Connections और कनेक्शन जोड़ें का चयन करें ... URL निर्दिष्ट करें और ठीक पर क्लिक करें।

Step 2 - विस्तार करें SharePoint Tutorials → List Libraries → Lists → Authors → Fields → Salary/Rateमैदान। दाएँ क्लिक करेंSalary/Rateऔर गुण चुनें। आप देखेंगेInternalName गुण विंडो में।

Step 3 - नीचे दिए गए वेतन / दर के आधार पर लेखकों को प्राप्त करने और उनके वेतन / दर को बढ़ाने का एक सरल उदाहरण है।

using Microsoft.SharePoint;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ServerObjectModel {
   class Program {
      static void Main(string[] args) {
         using (var site = new SPSite("http://waqasserver/sites/demo")) {
            var web = site.RootWeb;
            var list = web.Lists.TryGetList("Authors");
            if (list == null)
            return;
            var items = list.Items;
            ShowItems(items);
            RaiseRates(items);
            Console.WriteLine("\nAfter Raise\n");
            ShowItems(items);
            Console.ReadKey();
         }
      }
      static void RaiseRates(SPListItemCollection items) {
         foreach (SPListItem item in items) {
            var employee = Convert.ToBoolean(item["Employee"]);
            var rate = Convert.ToDouble(item["Salary_x002f_Rate"]);
            var newRate = employee ? rate + 1 : rate + 0.1;
            item["Salary_x002f_Rate"] = newRate;
            item.Update();
         }
      }
      static void ShowItems(SPListItemCollection items) {
         foreach (SPListItem item in items) {
            Console.WriteLine("Salary or rate for {0} is {1:c}", item.Title,
            item["Salary_x002f_Rate"]);
         }
      }
   }
}

उपरोक्त कोड में आप देख सकते हैं कि हमारे पास दो तरीके हैं -

  • एक उस सूची को पुनः प्राप्त कर रहा है जिसे कहा जाता है ShowItems तथा

  • दूसरी विधि दरों को बढ़ा रही है जिसे कहा जाता है RaiseRates()

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

Salary or rate for Muhammad Waqas is $950.00 Salary or rate for Mark Upston is $15.00
Salary or rate for Allan Bommer is $20.00 Salary or rate for Andy Onian is $870.00

After Raise

Salary or rate for Muhammad Waqas is $951.00 Salary or rate for Mark Upston is $15.10
Salary or rate for Allan Bommer is $20.10 Salary or rate for Andy Onian is $871.00

CAML प्रश्न

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

यह वास्तव में एक SQL क्वेरी में तालिका नाम से एक का चयन * करने के लिए analogues है।

हम इस मुद्दे को संबोधित कर सकते हैं कि क्या कहा जाता है CAML queries। CAML क्वेरी करते समय आपके पास दो विकल्प होते हैं -

  • यदि आप केवल एक सूची को क्वेरी करना चाहते हैं, तो आप SPQuery ऑब्जेक्ट का उपयोग कर सकते हैं।

  • यदि आप साइट संग्रह में कई सूचियों को क्वेरी करना चाहते हैं, तो आप SPSiteDataQuery का उपयोग कर सकते हैं।

आम तौर पर, जब आप कर रहे हैं SPSiteDataQuery, आप एक विशिष्ट प्रकार की सभी सूचियों को क्वेरी कर रहे हैं।

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

CAML प्रश्नों का सिंटैक्स मूल रूप से XML प्रारूप में वर्णित है और इस प्रकार के प्रश्नों का निर्माण करने में थोड़ा समय लगता है।

हमें CAML क्वेरीज़ के एक सरल उदाहरण पर एक नज़र डालते हैं। यहां, हम अपनी लेखकों की सूची में डेटा को क्वेरी करने के लिए एक CAML क्वेरी बनाएंगे।

using Microsoft.SharePoint;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ServerObjectModel {
   class Program {
      static void Main(string[] args) {
         using (var site = new SPSite("http://waqasserver/sites/demo")) {
            var web = site.RootWeb;
            var list = web.Lists.TryGetList("Authors");
            if (list == null)
            return;
            var items = QueryItems(list);
            ShowItems(items);
            
            //RaiseRates(items);
            //Console.WriteLine("\nAfter Raise\n");
            //ShowItems(items);
            Console.ReadKey();
         }
      }
      static SPListItemCollection QueryItems(SPList list) {
         var query = new SPQuery();
         
         query.ViewFields =
            "<FieldRef Name='Title' />" +
            "<FieldRef Name='Employee' />" +
            "<FieldRef Name='Salary_x002f_Rate' />";
         
         query.Query =
            "<OrderBy>" +
            " <FieldRef Name='Salary_x002f_Rate' />" +
            "</OrderBy>" +
            "<Where>" +
            " <Eq>" +
            " <FieldRef Name='Employee' />" +
            " <Value Type='Boolean'>False</Value>" +
            " </Eq>" +
            "</Where>";
         return list.GetItems(query);
      }
      static void RaiseRates(SPListItemCollection items) {
         foreach (SPListItem item in items) {
            var employee = Convert.ToBoolean(item["Employee"]);
            var rate = Convert.ToDouble(item["Salary_x002f_Rate"]);
            var newRate = employee ? rate + 1 : rate + 0.1;
            item["Salary_x002f_Rate"] = newRate;
            item.Update();
         }
      }
      static void ShowItems(SPListItemCollection items) {
         foreach (SPListItem item in items) {
            Console.WriteLine("Salary or rate for {0} is {1:c}",
            item.Title,
            item["Salary_x002f_Rate"]);
         }
      }
   }
}

हमने कुछ वस्तुओं को प्राप्त करने के लिए एक CAML क्वेरी का उपयोग किया है। मेंQueryItems विधि, आप देख सकते हैं कि हमने केवल उन वस्तुओं को पुनः प्राप्त किया है जो कर्मचारी नहीं हैं।

Salary or rate for Mark Upston is $15.10 Salary or rate for Allan Bommer is $20.10