前言:使用过SharePoint的人都知道,SharePoint对于操作是便捷的,但是对于数据量承载却是不令人满意的,这样,就要求我们需要更加合理的使用,规范大家的使用规则和习惯,所以,定期清理不必要的文档也就成为了一个问题。

  考虑到这一点,我觉得写一个小工具,用来实现文档归档,是比较方便的办法。当然,如果你愿意,可以封装为TimerJob或者Windows Service都是没有问题的,甚至于Windows计划任务也都是可行的,只要你愿意。

一、 界面设计:

  如上图,首先需要输入下载文档需要的用户名、密码、域的名字,否则我们是没有权限下载文档的;

  然后是站点地址,打开SPSite,会同时加载出来所有的SPWeb;

  然后选择我们需要的SPWeb,会自动加载出来所有的文档库;

  选择我们需要的文档库,选择日期,早于这个日期的所有文档,都在归档的范围内;

  勾选自动删除已归档文档,这样会删除已经下载到指定路径的文档,并且不会出现在回收站。

二、 设计思路:

  很简单的思路,大神勿喷,感谢!

  基于SharePoint 2010 Server版本,服务器端对象模型,需要运行在服务器上。

  通过服务器端对象模型,获取所有的SPListItem集合,通过WebClient对象,把所有早于归档日期的文档下载下来,然后Item.Delete()掉已经下载了的文档,当然,只是为了完成归档的任务,没有太丰富的功能。

  如果不删除文档库的文档,也可以使用它来下载文档库的文档,感觉比在Windows资源管理器里打开,进行复制粘贴的速度要快一些。

三、 部分代码:

  批量删除部分的代码,没有通过Caml语句筛选,可能有些很X很暴力,还请见谅,需要的话,可以优化。

SPList list = web.Lists[ListID];

SPListItemCollection itemcoll = list.Items;

string strURL = string.Empty;

int maxNum = itemcoll.Count;

progressBarBackUp.Maximum = maxNum;

for (int i = maxNum - 1; i >= 0; i--)

{

try

{

if (Convert.ToDateTime(itemcoll[i]["Created"].ToString()) > Convert.ToDateTime(dateTimePicker1.Text))//可以优化~~~~~~~~~

{

continue;

}

strURL = web.Url + "/" + itemcoll[i].Url;

BackUpDoc(strURL);

if (cbAutoDel.Checked)

{

itemcoll[i].Delete();

//itemcoll[i].Update();

}

}

catch

{

}

progressBarBackUp.Value ++;

}

  如下,下载文档的方法,通过URL下载文档到指定路径;

Ø public void BackUpDoc(string url)

Ø {

Ø try

Ø {

Ø string strFileName = string.Empty;

Ø int l1 = url.LastIndexOf('/');

Ø strFileName = "/" + url.Substring(l1, url.Length - l1);

Ø NetworkCredential nc = new NetworkCredential(tbUserName.Text, tbPassWord.Text, tbDomain.Text);

Ø WebClient wc = new WebClient();

Ø wc.Credentials = nc;

Ø byte[] file = wc.DownloadData(url);

Ø File.WriteAllBytes(tbSavePath.Text + strFileName, file);

Ø }

Ø catch

Ø {

Ø }

Ø }

四、 功能演示

  首先,我在文档库<知识积累>里面,批量上传一些文档,因为是测试,都是一些比较乱七八糟的文档,莫见怪~~~O(∩_∩)O~

  然后,打开工具,输入用户名、密码、域名;输入网站地址,打开网站;选择站点,选择文档库;选择时间,点击归档,运行如下图:

  如下图,都已经下载到桌面上的ls文件夹中了

  查看原来的文档库,刷新看一下,如下图:

  查看回收站,也没有我们删除的文档,如下图:

  工具下载地址:http://files.cnblogs.com/jianyus/DocLibBackUpTool.rar

  后记:随便写一个练手的工具,有兴趣的可以看看,大神勿喷~~最近有点怕怕了,都不敢写东西了,其实,本意就是分享~~有交流的可以留言,或者加入我的SharePoint QQ群,大家一起交流~~

SharePoint 2010 文档管理之过期归档工具的更多相关文章

  1. SharePoint 2010 文档管理系列

    前言,这是自己第一次写一个系列的文档,本来想使用SharePoint 2013版本,但是碍于SharePoint 2013对于硬件要求过高,自己的笔记本无法承受,所以退而求其次选择了在SharePoi ...

  2. SharePoint 2010 文档管理系列之星级评论功能

    前言:正如我们前面介绍的是,文档管理就是让大家更加直观.方便的对手里的文档,进行统筹掌控,哪些文档是有价值的,哪些文档更受大家欢迎,所有就带来了这个星级评论. 当然,这个是SharePoint 201 ...

  3. SharePoint 2010 文档管理系列之准备篇

    前言:很早自己就想写一个系列的文章,但是不知道写什么,最近在QQ群里,好多人说在做文档管理,其实文档管理也是SharePoint的一个很不错的功能点,自己想了想,也想多学习点东西,所以写这个主题吧,今 ...

  4. SharePoint 2010 文档管理系列之文档搜索

    前言:如果一个文档库里面有很多文档,成千上万,对我们来说查找就是个麻烦事儿,所以搜索的必要性就体现出来了.下面,我们简单的介绍下,sharepoint搜索配置,并创建一个简单的搜索页面. 一. 配置S ...

  5. SharePoint 2010 文档管理之文档推送

    前言:文档推送功能,不是一个复杂的功能,我们这里简单的应用了Ribbon定制.Js使用.对象模型推送(Server端),下面,我们来简单介绍下文档推送功能吧. 一. 功能设计: 文档推送功能,主要就是 ...

  6. SharePoint 2010 文档管理之点击次数

    前言:很多场景下,我们都需要对一篇文章或者文档的点击次数进行统计,然而SharePoint本身并没有给我们设计这样一个字段,所以我们需要通过简单的字段开发来实现这样一个功能. 一.创建项目: 1. 创 ...

  7. 【SharePoint 文档管理解决方案设计系列一】文档使用分析

    在我们在 SharePoint 端设计文档管理解决方案之前我们要了解目前客户在他们已有的系统里是怎么对文档进行使用和管理的.只有了解了当前的使用情况才能根据客户的需求量身定做一套适合他们的有效的解决方 ...

  8. OpenShare文档管理不完整功能清单

    文档结构管理 以网站集-网站的方式建立各部门的文档管理中心,让文档管理更加规范,使用户更加方便地进行浏览.查找和使用文档资源. 文档全生命周期管理 结合定制开发的工作流平台对文档的全生命周期(创建.获 ...

  9. LINUX文档管理命令

    body, table{font-family: 微软雅黑} table{border-collapse: collapse; border: solid gray; border-width: 2p ...

随机推荐

  1. 使用word和pdf进行仿书编辑的经验

    一.问题的提出:    一本书扫描好,要将书中的图片转换为文字版的word文档.二.问题的分析:    1.文字的提取    2.文字的编排三.问题的解决    1.如果用的是Adobe Acroba ...

  2. 安卓开发笔记——深入Activity

    在上一篇文章<安卓开发笔记——重识Activity >中,我们了解了Activity生命周期的执行顺序和一些基本的数据保存操作,但如果只知道这些是对于我们的开发需求来说是远远不够的,今天我 ...

  3. Log4net对文件的支持

    RollingFileAppender循环记录日志(指定文件最大长度) <appender name="RollingFileAppender" type="log ...

  4. java计算当前周开始日期&结束日期

    public static Date getFirstDayOfWeek(Date date) { Calendar c = new GregorianCalendar(); c.setFirstDa ...

  5. MyBatis知多少(22)MyBatis删除操作

    本节从表中使用MyBatis删除记录. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( id INT NOT NULL auto_increment, f ...

  6. AssetBundle系列——游戏资源打包(二)

    本篇接着上一篇.上篇中说到的4步的代码分别如下所示: (1)将资源打包成assetbundle,并放到自定目录下 using UnityEditor; using UnityEngine; using ...

  7. 【转载】一步一步写算法(之hash表)

    转载自:http://blog.csdn.net/feixiaoxing/article/details/6885657 [ 声明:版权所有,欢迎转载,请勿用于商业用途.  联系信箱:feixiaox ...

  8. 敏捷个人微信号:AgileMe ,欢迎大家推广和关注

  9. mysql修改definer方法

    -- 函数.存储过程 select definer from mysql.proc; update mysql.proc set definer='billing@%';   -- 定时事件 sele ...

  10. [JS] jQuery选择器

    jQuery 选择器 选择器 实例 选取 * $("*") 所有元素 #id $("#lastname") id=lastname 的元素 .class $(& ...