使用对象模型操作文档库(DocumentLibrary)-阿里云开发者社区

开发者社区> zting科技> 正文

使用对象模型操作文档库(DocumentLibrary)

简介:
+关注继续查看

1. 使用该类SPDocumentLibrary来实现一些对文档库的操作,文档库只是列表的一种特殊类型,所以当我们使用如下代码的时候,显示出的list是包括文档库的。
SPWeb site = SPContext.Current.Web;
foreach (SPList list in site.Lists) 
{
// 所有的列表,当然也包括文档库
}

2. 文档库和列表的主要不同点是文档库是用来存储文档的,SPDocumentLibrary类是继承自SPList的,所以当你获得SPList对象的时候就可以判断该列表是否为文档库
public bool IsListAlsoDocumentLibrary(SPList list)

    if(list is SPDocumentLibrary) 
        return true
    else   
        return false;
}

3. 站点可能有很多隐藏的文档库,比如webpart库,站点模板库,母板页库,我们可以把他们显示在一个DropDownList中,代码如下:
SPWeb site = SPContext.Current.Web;
foreach (SPList list in site.Lists) 

    if(list is SPDocumentLibrary && !list.Hidden) 
    {   
         SPDocumentLibrary docLib = (SPDocumentLibrary)list;   
         lstTargetLibrary.Items.Add(new ListItem(docLib.Title, docLib.ID.ToString())); 
}
}

4.1 由于文档库在wss的object model中也是SPList,所以每一个文档也是一个SPlistItem对象,然而在文档库中的文档
也可以为一个SPFile对象,所以我们可以通过这两种方法是操作。
void ProcessDocuments(SPDocumentLibrary docLib) { foreach(SPListItem item in docLib.Items) { // 操作SPListItem对象 SPFile file = item.File; // 操作SPFile 对象 } }
 

4.2 SPListItem对象记录了一个文档的ID,对栏元数据的读写,如下代码:
foreach (SPListItem item in docLib.Items)
{
    int itemID = item.ID;     // 读元数据栏信息
    string clientColumnValue = item["Client"].ToString();
    //写元数据栏信息
     item["Client"] = "AdventureWorks";
    item.Update();
}

4.3 SPFile一般来控制文档的内容,比如下面代码:
foreach (SPListItem item in docLib.Items)
{       
     if(item.FileSystemObjectType == SPFileSystemObjectType.File) 
     {            
          SPFile file = item.File;    
          int versionCount = file.Versions.Count;   
          // 是否被签出  
           DateTime checkedOutDate = file.CheckedOutDate;        
          // 基于流的方式打开处理       
           using(Stream fileContents = file.OpenBinaryStream())         
          {}     
     }
}

5. 这里需要注意的是如果文档库中有文件夹的时候,对应object model为一个内容为SPListItem的Items的集合,所以上面的代码中我在把SPListItem转换为SPFile前来判断SPFileSystemObjectType属性。

如果你仅仅想把站点中文档库都列举出来,你还可以通过如下方法:
void ProcessDocumentsAtRoot(SPDocumentLibrary docLib) 
{
     foreach (SPFile file in docLib.RootFolder.Files) 
     {
          // program against file using SPFile class
     
}
}

6.1 添加一个新的文件到文档库中,下面是主要代码:
protected void CreateDocument()
{
    SPSite siteCollection = SPContext.Current.Site;
    SPWeb site = SPContext.Current.Web;
    Guid libraryID = new Guid(lstTargetLibrary.SelectedValue);
    SPDocumentLibrary library = (SPDocumentLibrary)site.Lists[libraryID];

    string documentName = txtFileName.Text;
    string libraryRelativePath = library.RootFolder.ServerRelativeUrl;
    string libraryPath = siteCollection.MakeFullUrl(libraryRelativePath);
    string documentPath = libraryPath + "/" + documentName;

    Stream documentStream = new MemoryStream();
    StreamWriter writer = new StreamWriter(documentStream);
    writer.Write(txtDocumentBody.Text);
    writer.Flush();

    Hashtable docProperties = new Hashtable();
    docProperties["vti_title"] = "This is a test title";
    docProperties["Color"] = "Green";

    site.Files.Add(documentPath, documentStream, docProperties, true);
    Response.Redirect(libraryPath);
}

6.2 使用上面代码创建的文档,我们只是指定了"vti_title"和"Color"两个元数据的信息,wss默认为我们生成了许多,我们可以通过下面的代码来查看系统到底为我们做了什么?
SPList list = site.Lists["CaryPro"];
foreach (SPListItem item in list.Items) 
{
     SPFile file = item.File;
     foreach (DictionaryEntry entry in file.Properties) 
     {
         Console.WriteLine(entry.Key + ":" + entry.Value);
     }
     break;
}


7 使用Feature创建新的文档库实例

7.1 你可以使用网站设置中的UI,也可以自定义一个基于某个内容类型的文档库,我们可以Feature方式提供某个标准文档库的实例,如下设置:
<ListInstance
FeatureId="00BFEA71-E717-4E80-AA17-D0C71B360101"
TemplateType="101"
Id="CaryPro"
Description="Document Library for CaryPro"
OnQuickLaunch="True"
Title="CaryPro"
Url="CaryPro"
>
</ListInstance>

FeatureId必须是个GUID,TemplateType需要为文档库的类型,就是101

7.2 下面的配置为,在TestData目录有相应的文档,这些文档会默认就放到该文档库中
<Module Name="TestData" List="101" Path="TestData" Url="CaryPro" >
<File Url="AdventureCaryPro.docx" Type="GhostableInLibrary" />
<File Url="ContosoCaryPro.docx" Type="GhostableInLibrary" />
<File Url="WingtipCaryPro.docx" Type="GhostableInLibrary" />
</Module>

7.3 设置默认的文档库模板
<Module Name="WordTemplate" List="101" Url="CaryPro/Forms">
<File Url="CaryProTemplate.dotx" Type="GhostableInLibrary" />
</Module>

7.4 FeatureActivated中创建文档库
public override void FeatureActivated(SPFeatureReceiverProperties properties) 
{
    SPWeb site = (SPWeb)properties.Feature.Parent;
    SPDocumentLibrary libProposals = (SPDocumentLibrary)site.Lists["CaryPro"];
    string templateUrl = @"CaryPro/Forms/CaryProTemplate.dotx";
    libProposals.DocumentTemplateUrl = templateUrl;
    libProposals.Update();
}


本文转自生鱼片博客园博客,原文链接:http://www.cnblogs.com/carysun/archive/2008/07/05/DocumentLibrary.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
javascript:使用document.getElementById读取数据为空分析
  今天写个网页,想在页面加载onLoad时,动态显示由后台其他程序传来的数据时,用document.getElementById获取控件对象总是为空。但是检查了这个id确实是存在的。在网上查阅一番后才知道了其中的原因。
892 0
使用typeDoc快速生成开发文档
使用typeDoc快速生成开发文档
34 0
VB编程:利用CallByName函数对对象进行操作
VB编程:利用CallByName函数对对象进行操作
15 0
SpringBoot如何使用JPA操作数据库?
介绍如何在SpringBoot中使用JPA,并介绍JPA的相关知识点和原理
2938 0
使用ADO对象添加、修改、删除数据
使用ADO对象对数据库中的数据进行添加、修改和删除等操作。首先创建一个ADO类,通过ADO类连接数据库,并打开记录集。例如,使用ADO对象添加、修改、删除数据,程序设计步骤如下:(1)创建一个基于对话框的应用程序,将对话框的Caption属性修改“使用ADO对象添加、修改、删除数据”。
803 0
JavaScript创建对象(三)——原型模式
在JavaScript创建对象(二)——构造函数模式中提到,构造函数模式存在相同功能的函数定义多次的问题。本篇文章就来讨论一下该问题的解决方案——原型模式。
1044 0
+关注
3550
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载