SharePoint - Sunucu Nesne Modeli

Bu bölümde, SharePoint Sunucusu Nesne Modeline bir göz atacağız. SharePoint bağlamında çalışacak kod yazarken SharePoint Sunucusu Nesne Modelini kullanırsınız. Bazı yaygın örnekler, bir sayfadaki veya bir web bölümündeki arka planda kodlama, bir özelliğin veya listenin arkasındaki olay işleyicileri, zamanlayıcı işleri vb. Olabilir.

Sunucu Nesne Modelinin Özellikleri

Sunucu Nesne Modelinin temel özellikleri aşağıdadır

  • SharePoint tarafından kullanılan aynı uygulama havuzu içinde bir ASP.NET uygulaması programlıyorsanız, Sunucu Nesne Modeli'ni kullanabilirsiniz.

  • Sunucu Nesne Modeli, konsol veya Windows formları gibi bir istemci uygulaması veya SharePoint sunucusunda çalışacak bir WPF uygulaması geliştiriyorsanız kullanılabilir.

  • Bir SharePoint Sunucusuna uzaktan bağlanmak için Sunucu Nesne Modeli'ni kullanamazsınız.

  • Sunucu Nesne Modelini kullanmak istediğinizde, Microsoft.SharePointmontaj. Sunucu Nesne Modelini oluşturan başka derlemeler de vardır, ancak Microsoft.SharePoint ana olanıdır.

  • En yaygın olarak kullanacağınız çekirdek türleri, son kullanıcı olarak kullandığınız bileşenlerle eşleşir; bu nedenle site koleksiyonları, siteler, liste, kitaplıklar ve liste öğeleri gibi şeyler SPSite, SPWeb, SPList, SPDocumentLibrary ve SPListItem.

  • Bir site koleksiyonunu temsil eden tür ve Sunucu Nesne Modeli SPSite'dir ve Sunucu Nesne Modeli'nde bir SharePoint sitesini temsil eden tür SPWeb'dir. Bu nedenle, son kullanıcı terimlerinden geliştirici terimlerine geçtiğinizde, sadece bu zihinsel haritalamayı yapmanız gerekecektir.

Artık SharePoint'i ilk kullanmaya başladığınızda kafa karıştırıcı olabilir çünkü site çok fazla yüklüdür ve web sözlüğünden bahsetmeye gerek yok, son kullanıcı ve geliştirici sözlüğünde zıt şeyler anlamına gelir.

Basit bir Sunucu Nesne Modeli örneğine bakalım.

Step 1 - Visual Studio'yu açın ve buradan yeni bir proje oluşturun File → New → Project menü seçeneği.

Step 2 - Şuradan Windows'u seçin Templates → Visual C#sol bölmede ve orta bölmede Konsol Uygulaması'nı seçin. Projenizin adını girin ve Tamam'a tıklayın.

Step 3 - Proje oluşturulduktan sonra Solution Explorer'da projeye sağ tıklayın ve seçin Add → References.

Step 4 - Seçin Assemblies → Extensions sol bölmede ve orta bölmede Microsoft.SharePoint'i işaretleyin ve Tamam düğmesini tıklayın.

Şimdi Solution Explorer'da projeye tekrar sağ tıklayın ve Özellikler'i seçin.

Step 5 - tıklayın Build Sol bölmede sekme yapın ve Prefer 32-bit seçeneği.

Step 6 - Şimdi geri dön Program.cs dosyasını açın ve aşağıdaki kodla değiştirin.

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- Yukarıdaki kodda önce yeni bir SPSite nesnesi oluşturuldu. Bu tek kullanımlık bir nesnedir, bu nedenle bir using ifadesi içinde oluşturulur. SPSite kurucusu, sizin durumunuzda farklı olacak olan site koleksiyonunun URL'sini alır.

Var web = site.RootWeb site koleksiyonunun kökünü alacaktır.

Listeleri web.Lists kullanarak alabilir ve liste öğelerinin başlığını yazdırabiliriz.

Yukarıdaki kod derlendiğinde ve yürütüldüğünde, aşağıdaki çıktıyı göreceksiniz -

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

Bu başlıkların Çözümler Galerisi, Stil Kitaplığı, Form Şablonları olduğunu görebilirsiniz. Bunlar, SharePoint tarafından dahili olarak kullanılan listelerdir. Bu nedenle, tüm listeleri görüntülemek yerine, belki de yalnızca normalde kullanıcıların göreceği listeleri göstermek istersiniz.

Bu nedenle, tüm liste koleksiyonunu almak yerine, gizli olmayan tüm listeleri almak istiyoruz. Bunu aşağıdaki gibi bir bağlantı sorgusu kullanarak yapabiliriz.

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();
         }
      }
   }
}

Yukarıdaki kod derlendiğinde ve yürütüldüğünde, aşağıdaki çıktıyı göreceksiniz -

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

Bunun bize gizli olmayan tüm listeleri geri vereceğini görebilirsiniz.

Liste öğeleri hakkında bazı bilgileri de göstereceğimiz başka bir basit örneğe bakalım.

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();
         }
      }
   }
}

Yukarıdaki kod derlendiğinde ve yürütüldüğünde, aşağıdaki çıktıyı göreceksiniz -

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

Verileri Listele

Bir listeyi ilk oluşturduğunuzda, her zaman bir başlık sütunu vardır. Bu Başlık sütunu, varsayılan olarak Liste Öğesi bağlamına veya düzenleme kontrol bloğu menüsüne erişim sağlar.

Her liste bir sütunla başladığından - Başlık, SPListItemtype, bunu bir özellik olarak ortaya çıkarır. Her bir listede ortak olmayan sütunlar için, onlara indeksleyici aracılığıyla erişebilirsiniz.SpListItem yazın.

Dizin oluşturucuya birkaç bilgi aktarabilirsiniz, ancak en yaygın olanı Column. Liste ayarlarındaki son kullanıcılar bu adı değiştirebilir. Bu adı kullanmak istemezsiniz çünkü yine değişebilir.

İkincisi InternalName, bu listenin oluşturulduğu noktada ayarlanır ve asla değişmez. Bu, sütun değerine erişirken kullanmak istediğiniz addır.

Aşağıda gösterildiği gibi Yazarlar listesini alacağımız basit bir örneğe göz atalım -

Bu örnekte, Yazarlar listesini alacağız ve ardından Maaş / Oranı bir değer kadar artıracağız. Bu nedenle, Maaş / Oran sütunu için,InternalName.

Step 1- Sunucu Gezgini'ne gidin; sağ tıkSharePoint Connections ve Bağlantı Ekle ... seçeneğini seçin. URL'yi belirtin ve Tamam'ı tıklayın.

Step 2 - Genişlet SharePoint Tutorials → List Libraries → Lists → Authors → Fields → Salary/Ratealan. Sağ tıkSalary/Rateve Özellikler'i seçin. GöreceksinInternalName Özellikler penceresinde.

Step 3 - Aşağıda, Yazarları Maaş / Orana göre geri almanın ve Maaş / Oranlarını artırmanın basit bir örneği verilmiştir.

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"]);
         }
      }
   }
}

Yukarıdaki kodda iki yöntemimiz olduğunu görebilirsiniz -

  • Biri denilen listeyi alıyor ShowItems ve

  • Diğer yöntem ise Oranları yükseltmektir. RaiseRates().

Yukarıdaki kod derlendiğinde ve yürütüldüğünde, aşağıdaki çıktıyı göreceksiniz -

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 Sorguları

Yukarıdaki örneklerde, bir foreach döngüsü kullanarak öğeleri her zaman yineledik ve tüm öğeleri yineledik ve her zaman tüm sütunları geri getirdik veya en azından tüm sütunlar erişilebilir durumdaydı.

Bir SQL sorgusunda tablo adından bir seçme * yapmak gerçekten analogdur.

Bu sorunu çözebiliriz. CAML queries. Bir CAML sorgusu yaparken iki seçeneğiniz vardır -

  • Yalnızca tek bir listeyi sorgulamak istiyorsanız, SPQuery nesnesini kullanabilirsiniz.

  • Bir site koleksiyonundaki birden çok listeyi sorgulamak istiyorsanız, SPSiteDataQuery'yi kullanabilirsiniz.

Genellikle, SPSiteDataQuery, belirli bir türdeki tüm listeleri sorguluyorsunuz.

Örneğin, tüm kişi listelerini vb. Sorgulamak istiyorum. SPSiteDataQuery, kapsamı belirlemenize olanak tanır, böylece site koleksiyonunun tamamını, tek bir siteyi veya siteyi ve tüm alt öğelerini sorgulamak istediğinizi belirtebilirsiniz.

CAML sorgularının sözdizimi temelde XML biçiminde açıklanır ve bu tür sorguları oluşturmaya alışmak biraz zaman alır.

CAML Sorgularının basit bir örneğine bakalım. Burada, Yazarlar listemizdeki verileri sorgulamak için bir CAML sorgusu oluşturacağız.

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"]);
         }
      }
   }
}

Bazı öğeleri almak için bir CAML sorgusu kullandık. İçindeQueryItems yöntemiyle, yalnızca Çalışan olmayan öğeleri aldığımızı görebilirsiniz.

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