SharePoint - Modèle objet serveur

Dans ce chapitre, nous examinerons le modèle objet SharePoint Server. Vous utilisez le modèle objet SharePoint Server lorsque vous écrivez du code qui s'exécutera dans le contexte de SharePoint. Certains exemples courants sont le code-behind dans une page ou un composant WebPart, les gestionnaires d'événements derrière une fonctionnalité ou une liste, les travaux du minuteur, etc.

Caractéristiques du modèle d'objet serveur

Voici les principales caractéristiques du modèle d'objet serveur

  • Vous pouvez utiliser le modèle objet serveur si vous programmez une application ASP.NET dans le même pool d'applications que celui utilisé par SharePoint.

  • Le modèle d'objet serveur peut être utilisé si vous développez une application cliente telle qu'une console ou des formulaires Windows ou une application WPF qui s'exécutera sur un serveur SharePoint.

  • Vous ne pouvez pas utiliser le modèle objet serveur pour vous connecter à distance à un serveur SharePoint.

  • Lorsque vous souhaitez utiliser le modèle d'objet serveur, vous vous référez au Microsoft.SharePointAssemblée. Il existe d'autres assemblys, qui constituent le modèle d'objet serveur, mais Microsoft.SharePoint est le principal.

  • Les types de base que vous utiliserez le plus souvent mappent aux composants que vous utilisez en tant qu'utilisateur final, de sorte que des éléments tels que les collections de sites, les sites, la liste, les bibliothèques et les éléments de liste sont représentés par les types SPSite, SPWeb, SPList, SPDocumentLibrary et SPListItem.

  • Le type et le modèle objet serveur qui représentent une collection de sites est SPSite et le type qui représente un site SharePoint dans le modèle objet serveur est SPWeb. Par conséquent, lorsque vous passerez des termes de l'utilisateur final aux termes du développeur, vous n'aurez qu'à faire ce mappage mental.

Maintenant, lorsque vous commencez à utiliser SharePoint, cela peut être déroutant car le site est tellement surchargé et cela signifie des choses opposées dans le vocabulaire de l'utilisateur final et du développeur, sans parler du vocabulaire Web.

Jetons un coup d'œil à un exemple simple de modèle d'objet serveur.

Step 1 - Ouvrez Visual Studio et créez un nouveau projet à partir de File → New → Project option de menu.

Step 2 - Sélectionnez Windows dans Templates → Visual C#dans le volet gauche et choisissez Application console dans le volet central. Entrez le nom de votre projet et cliquez sur OK.

Step 3 - Une fois le projet créé, cliquez avec le bouton droit sur le projet dans l'Explorateur de solutions et sélectionnez Add → References.

Step 4 - Sélectionnez Assemblies → Extensions dans le volet gauche et cochez Microsoft.SharePoint dans le volet central et cliquez sur le bouton OK.

Cliquez à nouveau avec le bouton droit sur le projet dans l'Explorateur de solutions et sélectionnez Propriétés.

Step 5 - Cliquez sur le Build Tab dans le volet gauche et décochez la case Prefer 32-bit option.

Step 6 - Revenez maintenant au Program.cs et remplacez-le par le code suivant.

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- Dans le code ci-dessus, vous avez d'abord créé un nouvel objet SPSite. Il s'agit d'un objet jetable, il est donc créé dans une instruction using. Le constructeur SPSite prend l'URL de la collection de sites, qui sera différente dans votre cas.

Le var web = site.RootWeb obtiendra la racine de la collection de sites.

Nous pouvons obtenir les listes à l'aide de web.Lists et imprimer le titre des éléments de la liste.

Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante -

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

Vous pouvez voir que ces titres sont la Galerie de solutions, la bibliothèque de styles, les modèles de formulaires. Il s'agit de listes utilisées en interne par SharePoint. Par conséquent, au lieu d'afficher toutes les listes, vous souhaiterez peut-être afficher uniquement les listes que les utilisateurs verraient normalement.

Par conséquent, au lieu d'obtenir toute la collection de listes, nous voulons obtenir toutes les listes qui ne sont pas masquées. Nous pouvons le faire en utilisant une requête de lien comme indiqué ci-dessous.

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

Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante -

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

Vous pouvez voir que cela nous rendra toutes les listes qui ne sont pas cachées.

Jetons un œil à un autre exemple simple dans lequel nous afficherons également des informations sur les éléments de la liste.

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

Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante -

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

Données de liste

Lorsque vous créez une liste pour la première fois, elle comporte toujours une colonne de titre. Cette colonne Titre donne accès, par défaut, au contexte de l'élément de liste ou au menu du bloc de contrôle d'édition.

Depuis, chaque liste commence par une colonne - Titre, le SPListItemtype expose cela comme une propriété. Pour les colonnes qui ne sont pas communes à toutes les listes, vous pouvez y accéder via l'indexeur surSpListItem type.

Vous pouvez transmettre quelques informations à l'indexeur, mais la plus courante est la Column. Les utilisateurs finaux dans les paramètres de la liste peuvent modifier ce nom. Vous ne souhaitez pas utiliser ce nom car encore une fois, il peut changer.

Le second est le InternalName, qui est défini au moment où cette liste est créée et ne change jamais. Il s'agit du nom que vous souhaitez utiliser lorsque vous accédez à la valeur de la colonne.

Jetons un œil à un exemple simple dans lequel nous récupérerons la liste des auteurs comme indiqué ci-dessous -

Dans cet exemple, nous obtiendrons la liste des auteurs, puis augmenterons le salaire / taux d'une certaine valeur. Par conséquent, pour la colonne Salaire / Taux, nous utiliserons leInternalName.

Step 1- Allez dans l'Explorateur de serveurs; clic-droitSharePoint Connections et sélectionnez Ajouter une connexion ... Spécifiez l'URL et cliquez sur OK.

Step 2 - Développer SharePoint Tutorials → List Libraries → Lists → Authors → Fields → Salary/Ratechamp. Clic-droitSalary/Rateet sélectionnez Propriétés. Vous verrez leInternalName dans la fenêtre Propriétés.

Step 3 - Vous trouverez ci-dessous un exemple simple de récupération des auteurs en fonction du salaire / taux et d'augmenter leur salaire / taux.

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

Dans le code ci-dessus, vous pouvez voir que nous avons deux méthodes -

  • L'un récupère la liste qui s'appelle ShowItems et

  • L'autre méthode consiste à augmenter les taux qui s'appelle RaiseRates().

Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante -

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

Requêtes CAML

Dans les exemples ci-dessus, nous avons toujours parcouru les éléments en utilisant une boucle foreach plusieurs fois en parcourant tous les éléments et nous avons toujours ramené toutes les colonnes ou du moins toutes les colonnes étaient accessibles.

C'est vraiment analogue à faire une sélection * à partir d'un nom de table dans une requête SQL.

Nous pouvons résoudre ce problème en utilisant ce que l'on appelle CAML queries. Lorsque vous effectuez une requête CAML, vous avez deux options -

  • Si vous souhaitez interroger une seule liste, vous pouvez utiliser l'objet SPQuery.

  • Si vous souhaitez interroger plusieurs listes dans une collection de sites, vous pouvez utiliser SPSiteDataQuery.

Généralement, lorsque vous effectuez le SPSiteDataQuery, vous interrogez toutes les listes d'un type spécifique.

Par exemple, je souhaite interroger toutes les listes de contacts, etc. SPSiteDataQuery vous permet de déterminer la portée, de sorte que vous pouvez indiquer que vous souhaitez interroger la collection de sites entière, un site individuel ou le site et tous ses enfants.

La syntaxe des requêtes CAML est essentiellement décrite au format XML et il faut un peu de temps pour s'habituer à construire ce type de requêtes.

Jetons un coup d'œil à un exemple simple de requêtes CAML. Ici, nous allons créer une requête CAML pour interroger les données de notre liste d'auteurs.

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

Nous avons utilisé une requête CAML pour obtenir certains des éléments. dans leQueryItems méthode, vous pouvez voir que nous n'avons récupéré que les éléments qui ne sont pas des employés.

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