DesignPackage - Classe

Une classe statique qui est utilisée pour importer et exporter un package de création vers et à partir d'une collection de sites.

Hiérarchie d’héritage

System.Object
  Microsoft.SharePoint.Publishing.DesignPackage

Espace de noms :  Microsoft.SharePoint.Publishing
Assembly :  Microsoft.SharePoint.Publishing (dans Microsoft.SharePoint.Publishing.dll)

Syntaxe

'Déclaration
<AspNetHostingPermissionAttribute(SecurityAction.InheritanceDemand, Level := AspNetHostingPermissionLevel.Minimal)> _
<AspNetHostingPermissionAttribute(SecurityAction.LinkDemand, Level := AspNetHostingPermissionLevel.Minimal)> _
<SharePointPermissionAttribute(SecurityAction.LinkDemand, ObjectModel := True)> _
Public NotInheritable Class DesignPackage
'Utilisation
Il n’est pas nécessaire de déclarer l’instance d’une classe statique pour accéder à ses membres.
[AspNetHostingPermissionAttribute(SecurityAction.InheritanceDemand, Level = AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermissionAttribute(SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
[SharePointPermissionAttribute(SecurityAction.LinkDemand, ObjectModel = true)]
public static class DesignPackage

Exemples

L'exemple suivant montre comment exporter un package de création à partir d'une collection de sites source et de l'installer dans une autre collection de sites.

using System.IO;
using Microsoft.SharePoint;
using Microsoft.SharePoint.Publishing;

namespace PackagingSample
{
    class Program
    {
        const string srcSiteUrl = "http://<Server>/sites/<SourceSiteURL>";
        const string dstSiteUrl = "http://<Server>/sites/<DestinationSiteURL>";
        const string packageName = "MyPackage";     // null to use the default name

        static void Main(string[] args)
        {
            // Export a package from source site collection
            SPSite srcSite = new SPSite(srcSiteUrl);
            DesignPackageInfo info = DesignPackage.Export(srcSite, packageName, false);

            // The package is exported to the solution gallery with the name format <PackageName>-<MajorVersion>.<MinorVersion>
            string packageFileName = string.Format("{0}-{1}.{2}.wsp", info.PackageName, info.MajorVersion, info.MinorVersion);

            // Download the exported package from the solution gallery
            SPFile file = srcSite.RootWeb.GetFile(srcSiteUrl + "/_catalogs/solutions/" + packageFileName);
            using (Stream fileStream = file.OpenBinaryStream())
            {
                using (Stream packageFileStream = File.Create(@"C:\" + packageFileName))
                {
                    fileStream.CopyTo(packageFileStream);
                }
            }
            srcSite.Dispose();

            // Import the package into another site collection
            SPSite dstSite = new SPSite(dstSiteUrl);
            using (Stream fileStream = File.Open(@"C:\" + packageFileName, FileMode.Open))
            {
                SPFile packageFile = dstSite.RootWeb.GetFolder(dstSiteUrl + "/Documents").Files.Add(packageFileName, fileStream);
                DesignPackage.Install(dstSite, info, packageFile.Url);
                DesignPackage.Apply(dstSite, info);
            }
            dstSite.Dispose();
        }
    }
}

Cohérence de thread

Tous les membres statique (Partagé dans Visual Basic)s publics de ce type sont thread-safe. Cela n’est pas garanti pour les membres d’instance.

Voir aussi

Référence

DesignPackage - Membres

Microsoft.SharePoint.Publishing - Espace de noms