Lire en anglais

Partager via


SiteMapProvider Classe

Définition

Fournit une classe de base commune à tous les fournisseurs de données de plan de site, et un moyen pour les développeurs d'implémenter des fournisseurs de données de plan de site personnalisés pouvant être utilisés avec l'infrastructure de plan de site ASP.NET sous forme de magasins persistants pour les objets SiteMap.

public abstract class SiteMapProvider : System.Configuration.Provider.ProviderBase
Héritage
SiteMapProvider
Dérivé

Exemples

L’exemple de code suivant montre comment écrire une classe qui implémente la classe abstraite SiteMapProvider . Cet exemple inclut uniquement un exemple SiteMapProvider et un exemple de fichier texte qui fonctionnent avec celui-ci. Pour exécuter l’exemple, vous avez également besoin d’une entrée dans le fichier Web.config et d’une page .aspx. Vous les trouverez dans la documentation de la SiteMapDataSource.SiteMapProvider propriété .

L’exemple utilise un fichier délimité par des virgules qui suit une structure attendue pour charger les informations de plan de site. La première ligne du fichier représente le nœud racine du plan de site, et les lignes suivantes sont des sous-nœuds. Chaque sous-nœud identifie son nœud parent par URL. Vous trouverez ci-dessous un exemple de fichier qui répond à ces critères.

default.aspx,Home,MyCompany Home Page,  
sale.aspx,Now On Sale,Check Out These Great Deals!,default.aspx  
catalog.aspx,Online Catalog,Browse Our Many Great Items!,default.aspx  

Le SimpleTextSiteMapProvider fournit des exemples d’implémentations de toutes les SiteMapProvider propriétés et méthodes.

using System;
using System.Configuration.Provider;
using System.Collections;
using System.Collections.Specialized;
using System.IO;
using System.Security.Permissions;
using System.Web;

namespace Samples.AspNet.CS
{

  [AspNetHostingPermission(SecurityAction.Demand, Level = AspNetHostingPermissionLevel.Minimal)]
  public class SimpleTextSiteMapProvider : SiteMapProvider
  {
    private SiteMapProvider parentSiteMapProvider = null;
    private string simpleTextProviderName = null;
    private string sourceFilename = null;
    private SiteMapNode rootNode = null;
    private ArrayList siteMapNodes = null;
    private ArrayList childParentRelationship = null;

    // A default constructor. The Name property is initialized in the
    // Initialize method.
    public SimpleTextSiteMapProvider()
    {
    }
    // Implement the CurrentNode property.
    public override SiteMapNode CurrentNode
    {
      get
      {
        string currentUrl = FindCurrentUrl();
        // Find the SiteMapNode that represents the current page.
        SiteMapNode currentNode = FindSiteMapNode(currentUrl);
        return currentNode;
      }
    }

    // Implement the RootNode property.
    public override SiteMapNode RootNode
    {
      get
      {
        return rootNode;
      }
    }
    // Implement the ParentProvider property.
    public override SiteMapProvider ParentProvider
    {
      get
      {
        return parentSiteMapProvider;
      }
      set
      {
        parentSiteMapProvider = value;
      }
    }

    // Implement the RootProvider property.
    public override SiteMapProvider RootProvider
    {
      get
      {
        // If the current instance belongs to a provider hierarchy, it
        // cannot be the RootProvider. Rely on the ParentProvider.
        if (this.ParentProvider != null)
        {
          return ParentProvider.RootProvider;
        }
        // If the current instance does not have a ParentProvider, it is
        // not a child in a hierarchy, and can be the RootProvider.
        else
        {
          return this;
        }
      }
    }
    // Implement the FindSiteMapNode method.
    public override SiteMapNode FindSiteMapNode(string rawUrl)
    {

      // Does the root node match the URL?
      if (RootNode.Url == rawUrl)
      {
        return RootNode;
      }
      else
      {
        SiteMapNode candidate = null;
        // Retrieve the SiteMapNode that matches the URL.
        lock (this)
        {
          candidate = GetNode(siteMapNodes, rawUrl);
        }
        return candidate;
      }
    }
    // Implement the GetChildNodes method.
    public override SiteMapNodeCollection GetChildNodes(SiteMapNode node)
    {
      SiteMapNodeCollection children = new SiteMapNodeCollection();
      // Iterate through the ArrayList and find all nodes that have the specified node as a parent.
      lock (this)
      {
        for (int i = 0; i < childParentRelationship.Count; i++)
        {

          string nodeUrl = ((DictionaryEntry)childParentRelationship[i]).Key as string;

          SiteMapNode parent = GetNode(childParentRelationship, nodeUrl);

          if (parent != null && node.Url == parent.Url)
          {
            // The SiteMapNode with the Url that corresponds to nodeUrl
            // is a child of the specified node. Get the SiteMapNode for
            // the nodeUrl.
            SiteMapNode child = FindSiteMapNode(nodeUrl);
            if (child != null)
            {
              children.Add(child as SiteMapNode);
            }
            else
            {
              throw new Exception("ArrayLists not in sync.");
            }
          }
        }
      }
      return children;
    }
    protected override SiteMapNode GetRootNodeCore()
    {
      return RootNode;
    }
    // Implement the GetParentNode method.
    public override SiteMapNode GetParentNode(SiteMapNode node)
    {
      // Check the childParentRelationship table and find the parent of the current node.
      // If there is no parent, the current node is the RootNode.
      SiteMapNode parent = null;
      lock (this)
      {
        // Get the Value of the node in childParentRelationship
        parent = GetNode(childParentRelationship, node.Url);
      }
      return parent;
    }

    // Implement the ProviderBase.Initialize property.
    // Initialize is used to initialize the state that the Provider holds, but
    // not actually build the site map.
    public override void Initialize(string name, NameValueCollection attributes)
    {

      lock (this)
      {

        base.Initialize(name, attributes);

        simpleTextProviderName = name;
        sourceFilename = attributes["siteMapFile"];
        siteMapNodes = new ArrayList();
        childParentRelationship = new ArrayList();

        // Build the site map in memory.
        LoadSiteMapFromStore();
      }
    }
    // Private helper methods

    private SiteMapNode GetNode(ArrayList list, string url)
    {
      for (int i = 0; i < list.Count; i++)
      {
        DictionaryEntry item = (DictionaryEntry)list[i];
        if ((string)item.Key == url)
          return item.Value as SiteMapNode;
      }
      return null;
    }

    // Get the URL of the currently displayed page.
    private string FindCurrentUrl()
    {
      try
      {
        // The current HttpContext.
        HttpContext currentContext = HttpContext.Current;
        if (currentContext != null)
        {
          return currentContext.Request.RawUrl;
        }
        else
        {
          throw new Exception("HttpContext.Current is Invalid");
        }
      }
      catch (Exception e)
      {
        throw new NotSupportedException("This provider requires a valid context.",e);
      }
    }
    protected virtual void LoadSiteMapFromStore()
    {
      string pathToOpen;

      lock (this)
      {
        // If a root node exists, LoadSiteMapFromStore has already
        // been called, and the method can return.
        if (rootNode != null)
        {
          return;
        }
        else
        {
          pathToOpen = HttpContext.Current.Server.MapPath("~" + "\\" + sourceFilename);

          if (File.Exists(pathToOpen))
          {
            // Open the file to read from.
            using (StreamReader sr = File.OpenText(pathToOpen))
            {

              // Clear the state of the collections and rootNode
              rootNode = null;
              siteMapNodes.Clear();
              childParentRelationship.Clear();

              // Parse the file and build the site map
              string s = "";
              string[] nodeValues = null;
              SiteMapNode temp = null;

              while ((s = sr.ReadLine()) != null)
              {

                // Build the various SiteMapNode objects and add
                // them to the ArrayList collections. The format used
                // is: URL,TITLE,DESCRIPTION,PARENTURL

                nodeValues = s.Split(',');

                temp = new SiteMapNode(this,
                    HttpRuntime.AppDomainAppVirtualPath + "/" + nodeValues[0],
                    HttpRuntime.AppDomainAppVirtualPath + "/" + nodeValues[0],
                    nodeValues[1],
                    nodeValues[2]);

                // Is this a root node yet?
                if (null == rootNode &&
                    string.IsNullOrEmpty(nodeValues[3]))
                {
                  rootNode = temp;
                }

              // If not the root node, add the node to the various collections.
                else
                {
                  siteMapNodes.Add(new DictionaryEntry(temp.Url, temp));
                  // The parent node has already been added to the collection.
                  SiteMapNode parentNode =
                           FindSiteMapNode(HttpRuntime.AppDomainAppVirtualPath + "/" + nodeValues[3]);
                  if (parentNode != null)
                  {
                    childParentRelationship.Add(new DictionaryEntry(temp.Url, parentNode));
                  }
                  else
                  {
                    throw new Exception("Parent node not found for current node.");
                  }
                }
              }
            }
          }
          else
          {
            throw new Exception("File not found");
          }
        }
      }
      return;
    }
  }
}

Remarques

Les StaticSiteMapProvider classes et XmlSiteMapProvider représentent les implémentations par défaut de la classe abstraite SiteMapProvider . utilise un fichier XML nommé Web.plan du site pour stocker les XmlSiteMapProvider données de plan de site. Pour plus d’informations sur le fichier Web.plan du site, consultez ASP.NET Cartes de sites.

La SiteMapProvider classe prend en charge le concept de hiérarchie de fournisseur de plan de site, en déclarant les RootProvider propriétés et ParentProvider . Un SiteMapProvider peut être un enfant ou un parent d’un autre fournisseur. Cela permet des scénarios dans lesquels différentes zones de contenu d’un site sont détenues ou implémentées par différents groupes de développement qui gèrent leurs propres cartes de site et fournisseurs de plan de site.

Tous les SiteMapProvider objets sont configurés dans les fichiers Web.config. Tous les fournisseurs de plan de site déclarés dans ces fichiers de configuration sont chargés au moment de l’exécution et utilisés pour charger et traiter les données de navigation du site. L’objet SiteMap , qui effectue le suivi de tous les fournisseurs qui lui sont accessibles via sa Providers collection de propriétés, fournit un accès programmatique aux données de navigation gérées par les fournisseurs. L’exemple de code suivant illustre le format utilisé pour déclarer un fournisseur de plan de site dans un fichier Web.config.

<siteMap defaultProvider="<name>">  
  <providers>  
    <add  
      name="<friendly name>"  
      type="<fully qualified class name>, <assembly name (optional)>"   
      siteMapFile = "<file name>" />  
  </providers>  
</siteMap>  

Les données de navigation de site chargées par ces fournisseurs sont utilisées par d’autres composants de l’infrastructure de plan de site, tels que les SiteMapPath contrôles et TreeView , pour afficher des informations de plan de site pour les utilisateurs.

Si vous implémentez votre propre fournisseur de plan de site, vous pouvez placer le fichier source dans le répertoire App_Code de votre application ASP.NET, puis l’assembly est compilé automatiquement. Vous pouvez également placer votre propre fournisseur de plan de site dans le Global Assembly Cache (GAC) et lui fournir une référence complète dans le fichier Web.config. Pour plus d’informations sur les services du compilateur, consultez Utilisation des assemblys et du Global Assembly Cache.

Notes pour les responsables de l’implémentation

Lorsque vous héritez de la SiteMapProvider classe , vous devez remplacer les membres suivants : GetRootNodeCore(), FindSiteMapNode(String), GetChildNodes(SiteMapNode)et GetParentNode(SiteMapNode).

Constructeurs

SiteMapProvider()

Initialise une nouvelle instance de la classe SiteMapProvider.

Propriétés

CurrentNode

Obtient l'objet SiteMapNode qui représente la page actuellement demandée.

Description

Obtient une description brève et conviviale qui peut s'afficher dans les outils d'administration ou d'autres interfaces utilisateur.

(Hérité de ProviderBase)
EnableLocalization

Obtient ou définit une valeur Boolean qui indique si des valeurs localisées des attributs SiteMapNode sont retournées.

Name

Obtient le nom convivial qui référence le fournisseur au cours de la configuration.

(Hérité de ProviderBase)
ParentProvider

Obtient ou définit l'objet SiteMapProvider parent du fournisseur actuel.

ResourceKey

Obtient ou définit la clé de ressource utilisée pour localiser des attributs SiteMapNode.

RootNode

Obtient l'objet racine SiteMapNode des données de plan de site que le fournisseur actuel représente.

RootProvider

Obtient l'objet SiteMapProvider racine dans la hiérarchie de fournisseur actuelle.

SecurityTrimmingEnabled

Obtient une valeur Boolean qui indique si un fournisseur de plan de site filtre ou non des nœuds en fonction du rôle d'un utilisateur.

Méthodes

AddNode(SiteMapNode)

Ajoute un objet SiteMapNode à la collection de nœuds gérée par le fournisseur de plan de site.

AddNode(SiteMapNode, SiteMapNode)

Ajoute un objet SiteMapNode à la collection de nœuds gérée par le fournisseur de plan de site et spécifie l'objet SiteMapNode parent.

Equals(Object)

Détermine si l'objet spécifié est égal à l'objet actuel.

(Hérité de Object)
FindSiteMapNode(HttpContext)

Récupère un objet SiteMapNode qui représente la page actuellement demandée à l'aide de l'objet HttpContext spécifié.

FindSiteMapNode(String)

En cas de substitution dans une classe dérivée, il récupère un objet SiteMapNode qui représente la page présente à l'URL spécifiée.

FindSiteMapNodeFromKey(String)

Récupère un objet SiteMapNode selon une clé spécifiée.

GetChildNodes(SiteMapNode)

En cas de substitution dans une classe dérivée, il récupère le nœud enfant d'un objet SiteMapNode spécifique.

GetCurrentNodeAndHintAncestorNodes(Int32)

Fournit une méthode de recherche optimisée pour les fournisseurs de plan de site lors de la récupération du nœud pour la page actuellement demandée et lors de l'extraction des nœuds de plan de site parents et ancêtres de la page actuelle.

GetCurrentNodeAndHintNeighborhoodNodes(Int32, Int32)

Fournit une méthode de recherche optimisée aux fournisseurs de plan de site lors de la récupération du nœud pour la page actuellement demandée et lors de l'extraction de nœuds de plan de site situés à proximité du nœud actuel.

GetHashCode()

Fait office de fonction de hachage par défaut.

(Hérité de Object)
GetParentNode(SiteMapNode)

En cas de substitution dans une classe dérivée, il récupère le nœud parent d'un SiteMapNode spécifique.

GetParentNodeRelativeToCurrentNodeAndHintDownFromParent(Int32, Int32)

Fournit une méthode de recherche optimisée pour les fournisseurs de plan de site lors de la récupération d'un nœud ancêtre pour la page actuellement demandée et lors de l'extraction des nœuds descendants pour l'ancêtre.

GetParentNodeRelativeToNodeAndHintDownFromParent(SiteMapNode, Int32, Int32)

Fournit une méthode de recherche optimisée pour les fournisseurs de plan de site lors de la récupération d'un nœud ancêtre pour l'objet SiteMapNode spécifié et lors de l'extraction de ses nœuds enfants.

GetRootNodeCore()

Lorsqu'il est substitué dans une classe dérivée, il récupère le nœud racine de tous les nœuds gérés par le fournisseur actuel.

GetRootNodeCoreFromProvider(SiteMapProvider)

Récupère le nœud racine de tous les nœuds actuellement gérés par le fournisseur de plan de site spécifié.

GetType()

Obtient le Type de l'instance actuelle.

(Hérité de Object)
HintAncestorNodes(SiteMapNode, Int32)

Fournit une méthode que les fournisseurs de plan de site peuvent substituer pour exécuter une récupération optimisée d'un ou plusieurs niveaux de nœuds parents et ancêtres relatifs à l'objet SiteMapNode spécifié.

HintNeighborhoodNodes(SiteMapNode, Int32, Int32)

Fournit une méthode que les fournisseurs de plan de site peuvent substituer pour exécuter une récupération optimisée des nœuds trouvés à proximité du nœud spécifié.

Initialize(String, NameValueCollection)

Initialise l'implémentation de SiteMapProvider, y compris toutes les ressources nécessaires pour charger des données de plan de site à partir d'un stockage persistant.

IsAccessibleToUser(HttpContext, SiteMapNode)

Récupère une valeur Boolean qui indique si l'objet SiteMapNode spécifié peut être affiché par l'utilisateur dans le contexte spécifié.

MemberwiseClone()

Crée une copie superficielle du Object actuel.

(Hérité de Object)
RemoveNode(SiteMapNode)

Supprime l'objet SiteMapNode spécifié dans la collection de nœuds gérée par le fournisseur de plan de site.

ResolveSiteMapNode(HttpContext)

Déclenche l’événement SiteMapResolve.

ToString()

Retourne une chaîne qui représente l'objet actuel.

(Hérité de Object)

Événements

SiteMapResolve

Se produit lorsque la propriété CurrentNode est appelée.

S’applique à

Produit Versions
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

Voir aussi