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.