SharePoint中在线编辑文档
我一直以为只有在Document Library里面的File才会支持在线编辑。直到今天早上我才发现用IE打开List里面的Attachments也是支持在线编辑的,但前提是必须是IE浏览器。
目前正在开发的项目,我开始设计时是把所有的审批信息存放在List中,上传的文档以Attachments形式保存于List中,昨天客户来公司,我演示的时候,用Chrome打开附件,直接下载了(以后建议用IE),客户需要在线编辑功能,还狠狠的批了我们一顿,附件不能在线编辑,那我审核个毛线。(其实是可以的,用IE就行。)结束后,我也没多想(经验不足)直接对代码进行该了,将FileUpload上传的文件保存到一个Document Library 的Log中,其实这完全是多余的。
如果你想在SharePoint中,想对上传的文档进行在线的编辑,有2种方法,一种当然是上传到文档库啦,还有一种就是以Attachments上传到List。
List
首先,对ListItem进行Update操作。
if (fileAttachment.HasFile)
{
try
{
foreach (var file in fileAttachment.PostedFiles)
{
newItem.Attachments.Add(file.FileName, file.InputStream.ReadFully());
}
}
catch ()
{ }
}
newItem.Update();
然后List的ListItem编辑Webpart中,用HyperLink画出附件,其实就是获取附件的Url地址
SPListItem newItem = this._applyItemList.GetItemById(this.ObjectId);
HyperLink hyperLink=null;
foreach (string currentAttachment in newItem.Attachments)
{
hyperLink=new HyperLink();
hyperLink.ID = Guid.NewGuid().ToString();
string attachmentAbsoluteURL = newItem.Attachments.UrlPrefix + currentAttachment;
SPFile attachmentFile = this._currentWeb.GetFile(attachmentAbsoluteURL);
hyperLink.Text = attachmentFile.Name;
hyperLink.NavigateUrl = attachmentAbsoluteURL;
phAttachment.Controls.Add(hyperLink);
//添加换行
phAttachment.Controls.Add(new LiteralControl("<br />"));
}
最后在编辑的Webpart如下所示,直接用IE打开,支持在线编辑,但没有历史记录

当然,你也可以将文档上传到文档库,上传到文档库里面你的操作有历史记录
Document Library
比如我将FileUpload上传的文件保存到文档库中的相应文件夹,以ListID+“-”+ListItemID命名的文件夹,这样避免了上传文档重名的问题,首先判断是否存在这个文件夹,不存在则创建,当创建完成后,将文档存放在文档库中此文件夹下:
if (fileAttachment.HasFile)
{
try
{
foreach (var file in fileAttachment.PostedFiles)
{
using (SPSite logSite = SPContext.Current.Site)
{
using (SPWeb logWeb = logSite.AllWebs["log"])
{
logWeb.AllowUnsafeUpdates = true; SPDocumentLibrary library = logWeb.Lists["ApproveAttachmentLog"] as SPDocumentLibrary;
string rootUrl = library.RootFolder.Url;
string listId = _applyItemList.ID.ToString();
string listItemId = newItem.ID.ToString();
string folderUrl = rootUrl + "/" + listId+"-" + listItemId;
SPFolder folder = logWeb.GetFolder(folderUrl); if (!folder.Exists)
{
SPListItem newFolder = library.Folders.Add(library.RootFolder.ServerRelativeUrl, SPFileSystemObjectType.Folder, listId +"-"+ listItemId);
newFolder.Update();
}
Stream stream = file.InputStream;
byte[] bytFile = new byte[Convert.ToInt32(file.ContentLength)];
stream.Read(bytFile, , Convert.ToInt32(file.ContentLength));
folder.Files.Add(System.IO.Path.GetFileName(file.FileName), bytFile, true); logWeb.AllowUnsafeUpdates = false; }
} }
}
catch (Exception)
{ }
}
接下来,就是获取文档库中File的AbsoluteUrl了,有一个非常漂亮的方法:file.Item[SPBuiltInFieldId.EncodedAbsUrl].ToString(),这样就可以获取当前File对应的ListItem的绝对地址了:
if (this.ObjectId>)
{
SPListItem newItem = this._applyItemList.GetItemById(this.ObjectId);
HyperLink hyperLink=null;
using (SPSite site = SPContext.Current.Site)
{
using (SPWeb web = site.AllWebs["log"])
{ SPDocumentLibrary library = web.Lists["ApproveAttachmentLog"] as SPDocumentLibrary;
string rootUrl = library.RootFolder.Url;
string listId = _applyItemList.ID.ToString();
string listItemId = newItem.ID.ToString();
string folderUrl = rootUrl + "/" + listId + "-" + listItemId;
SPFolder folder = web.GetFolder(folderUrl);
if (folder.Exists)
{
foreach (SPFile file in folder.Files)
{
hyperLink = new HyperLink();
hyperLink.ID = file.Item.ID.ToString();
hyperLink.Text = file.Item.Name;
hyperLink.NavigateUrl = file.Item[SPBuiltInFieldId.EncodedAbsUrl].ToString();
phAttachment.Controls.Add(hyperLink);
//添加换行
phAttachment.Controls.Add(new LiteralControl("<br />"));
}
}
}
}
效果入下,和上面展示的并无出入,但这样对文档的操作会有历史记录。

小结
对于文档的操作,推荐使用IE(doc、docx都是支持的),毕竟是微软的产品,对SharePoint支持也会很好。
SharePoint中在线编辑文档的更多相关文章
- C# 10分钟入门基于WebOffice实现在线编辑文档,实时保存到服务器(所有office,兼容WPS)
今天,他来了(weboffice在线编辑文档). 上次写了一个在线预览的博,当然,效果并不是太理想,但是紧急解决了当时的问题. 后来,小编重新查找资料,求助大牛,终于使用新的方式替换了之前的low方法 ...
- 在线office文档编辑NTKO使用心得
目录 前言 什么是ntko 准备工作 实战演练 总结 一.前言 Web开发中经常需要用到在线处理office文档的功能,现在市面上有一些常用的Web页面调用显示Office的控件技术,用起来很方便.有 ...
- 如何才能实现在点击链接时直接在网页中打开word文档,但不提示保存
一般要直接打开需要客户端 1.客户端有word支持 2.客户端浏览器的版本与设置 可寻找一下相关的控件或中间件,我的意见是看能否变通一下,把word转成HTML或PDF再展示给用户.(若用户不需要编辑 ...
- sharepoint 2010 如何创建文档库内容类型content type
转:http://biancheng.dnbcw.info/linux/441643.html 这次主要是记录下,如何来创建文档内容类型,例如新建文档的时候,可以选择不同模板,有word,excel文 ...
- 使用swagger实现web api在线接口文档
一.前言 通常我们的项目会包含许多对外的接口,这些接口都需要文档化,标准的接口描述文档需要描述接口的地址.参数.返回值.备注等等:像我们以前的做法是写在word/excel,通常是按模块划分,例如一个 ...
- 使用swagger实现web api在线接口文档(转载)
一.前言 通常我们的项目会包含许多对外的接口,这些接口都需要文档化,标准的接口描述文档需要描述接口的地址.参数.返回值.备注等等:像我们以前的做法是写在word/excel,通常是按模块划分,例如一个 ...
- Indri中的动态文档索引技术
Indri中的动态文档索引技术 戴维 译 摘要: Indri 动态文档索引的实现技术,支持在更新索引的同时处理用户在线查询请求. 文本搜索引擎曾被设计为针对固定的文档集合进行查询,对不少应用来说,这种 ...
- 浅析如何在Nancy中生成API文档
前言 前后端分离,或许是现如今最为流行开发方式,包括UWP.Android和IOS这样的手机客户端都是需要调用后台的API来进行数据的交互. 但是这样对前端开发和APP开发就会面临这样一个问题:如何知 ...
- spring boot / cloud (三) 集成springfox-swagger2构建在线API文档
spring boot / cloud (三) 集成springfox-swagger2构建在线API文档 前言 不能同步更新API文档会有什么问题? 理想情况下,为所开发的服务编写接口文档,能提高与 ...
随机推荐
- Selenium2(WebDriver)总结(四)---基本元素操作
WebDriver提供了常用的WEB控件的操作方法,比如:按钮.输入框.超链接等,废话不多说,直接上代码: import org.openqa.selenium.By; import org.open ...
- PageObject&PageFactory
几篇介绍PageObject&PageFactory文章: PageFactory: http://code.google.com/p/selenium/wiki/PageFactory Pa ...
- MDX Step by Step 读书笔记(九) - Working with Time 处理时间
开篇介绍 这一章节主要用到的 MDX 函数: PeriodsToDate( [Level , [Member]] ) - 从指定级别的范围内,返回与指定成员同一级别,从第一个期间开始到指定成员结束的期 ...
- vCenter Single Sign On 5.1 best practices
http://www.virtualizationteam.com/virtualization-vmware/vsphere-virtualization-vmware/vcenter-single ...
- 基于TQ2440开发板的WiFi模块的使用经验总结
一.软.硬件资源准备: 内核版本:linux-2.6.30.4 交叉编译器版本:4.3.3 wpa_supplicant工具:wpa_supplicant-0.7.3.tar ; openssl-0. ...
- SpringMVC学习笔记六:使用 hibernate-validator注解式数据校验
对客户端传过来的参数,在使用前一般需要进行校验. SpringMVC框架内置了Validator验证接口,但是实现起来太麻烦.我们一般使用 hibernate-validator进行数据校验. 1:j ...
- 图解Ajax工作原理
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6126542.html Ajax指Asynchronous JavaScript and XML(异步的 Jav ...
- psql 查询表大小
select schemaname,tablename,pg_relation_size(schemaname||'.'||tablename) as tabsize from pg_tables o ...
- requestsManager:didFailRequest:withError: Error Domain=com.albertodebortoli.goldraccoon Code=-1000 "(null)" UserInfo={message=Unknown error!}
场景:最近IOS开发中需要用到FTP上传,最初是用GoldRaccoon 看后台FTPServer日志,一直都是disconnected.自己对FTP也是懂些皮毛,所以只剩下一坑的无奈.FTP服务器是 ...
- 令Django 视图有默认 login_required
方法一 from django.template import RequestContext from django.shortcuts import render_to_response from ...