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文档会有什么问题? 理想情况下,为所开发的服务编写接口文档,能提高与 ...
随机推荐
- Redis分布式锁实现秒杀业务(乐观锁、悲观锁)
https://blog.csdn.net/lmb55/article/details/78266905
- C# WPF 滚动字幕实现
<Window x:Class="Micro.Crawler.MainWindow" xmlns="http://schemas.microsoft.com/win ...
- asp.net时间类-格式-方法应用
一.当前日期+时间DateTime.Now c#/asp.net通过DateTime.Now这个类来获取当前的时间. DateTime dt = DateTime.Now; 2013/10/24 10 ...
- JavaScript 之 动态加载JS代码或JS文件
2.动态加载JS文件 <script type="text/javascript"> function loadScript(url, callback) { var ...
- 转:nginx模块开发——handler(一)
handler模块简介 相信大家在看了前一章的模块概述以后,都对nginx的模块有了一个基本的认识.基本上作为第三方开发者最可能开发的就是三种类型的模块,即handler,filter和load-ba ...
- jquery vue 框架区别
1.数据和视图分离,解耦 2.以数据驱动视图,只关心数据变化,DOM操作被封装
- intellij 创建测试
之后再test目录下面创建java的文件夹,悲催的发现不能创建.想了好久,之后找到再本机的目录,手动创建java文件夹,然后点击test文件夹 ,并且点击下面的Tests文件夹 设置完test-> ...
- django之创建第12个项目-加载图片
百度云盘:django之创建第12个项目-加载图片 1.setting配置 #静态文件相关配置 # URL prefix for static files. # Example: "http ...
- windows 10 更新失败及应用商店重装问题解决记录
简单的记录一下这次遇到的问题及解决办法. 使用的windows 10 企业版一直不能更新成功,各种办法都试过了,都是失败然后回退. 这次直接下载了1709的映像进行升级安装的,因为我的是双系统,升级安 ...
- Android中使用DialogFragment来取代popopwindow
DialogFragment +fragment 来取代popopwindow +fragment 先留个标题,这几天过来写,重大发现