stp文件:SharePoint的.stp文件
在做一个和SharePoint有关的项目时,由于对SharePoint的unfamiliar,所以客户发了几个后缀为.stp的文件将我纳闷了半天,不知为何物。
按常理,只知道.stp文件是3D 的一个标准交换文件,需要用AutoCAD、PRO/E或SW等三维处理软件来打开,但看客户给我的文件大小非常小,应该不可能是3D文件啊。后来Avrin告诉我stp文件是Sharepoint里的Template file时我才恍然大悟,孤陋寡闻,惭愧啊....
这里的stp文件果然是SharePoint里的模板文件,用于将SharePoint里的List或site等结构保存下来以便移植到别的SharePoint上。实际上这个stp文件是个Cab文件,可以强行更改其后缀为.cab,直接打开或解压缩后可以看到里面的文件,其中有个manifest.xml的XML文件。关于这个的具体描述在另外一篇文章《SharePoint Customization: Using WSS List Templates in SPS Areas》里说得很详细,可以参考。
一、导出stp文件
1、打开SharePoint里的网站,在"Site Actions"下选择"Site Settings",然后选择Look and Feel栏下的"Save site as template"即可;
2、在SharePoint里打开一个List,点击"Settings"下的"List Settings",在“Permissions and Management”下点击"Save List as template"即可。
二、导入stp文件创建Site及List
打开SharePoint的Home页,点击Site Actions —> Site Settings —> Modify All Site Settings,在Galleries下选择Site templates或List templates进入Site Template Gallery页或List Template Gallery页,将相应的Site stp文件或List stp文件上传到Gallery。然后在新建网站或新建List时就可以选择上传的木板进行创建。
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Configuration; using System.IO; using Microsoft.SharePoint; using CodeArt.SharePoint; using CodeArt.SharePoint.CamlQuery; namespace BackFile { class Program { static void Main(string[] args) { string SPSiteUrl = ConfigurationManager.AppSettings["SPSiteUrl"]; string SPWebUrl = ConfigurationManager.AppSettings["SPWebUrl"]; string SPDocumentLibraryName = ConfigurationManager.AppSettings["SPDocumentLibrary"]; string BackupPath = ConfigurationManager.AppSettings["BackupPath"]; SPSite site = null; SPWeb rootWeb = null; SPSecurity.RunWithElevatedPrivileges(delegate() { using (site = new SPSite(SPSiteUrl)) { using (rootWeb = site.OpenWeb(SPWebUrl)) { } } }); SPDocumentLibrary doclib = (SPDocumentLibrary)rootWeb.Lists[SPDocumentLibraryName]; MakeFile(doclib.RootFolder, BackupPath); Console.ReadLine(); } public static void MakeFile(SPFolder folder, string BackupPath) { Console.WriteLine("Current Folder:" + folder.Url); string folderPath = BackupPath + "\" + folder.Url; if (!System.IO.Directory.Exists(folderPath)) { Console.WriteLine("Create Folder:" + folder.Url); Directory.CreateDirectory(folderPath); } foreach (SPFile file in folder.Files) { Console.WriteLine("Create File:" + folderPath + "\" + file.Name); byte[] bs = file.OpenBinary(); File.Create(folderPath + "\" + file.Name); } foreach (SPFolder subfolder in folder.SubFolders) { MakeFile(subfolder, BackupPath); } } } }