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