WebHttpRequest在sharepoint文档库中的使用

写在前面

由于sharepoint服务器上的站点采用的域用户windows认证的方式登陆,而app项目虽然能够提供用户名和密码,但客户是不愿意在网络上这样传输的。所以给提供了使用ssl证书认证的方式。而webhttprequest和sharepoint的Client object model 的结合还是蛮靠谱的,这里将采用这两种方式,带上证书发送请求进行上传文件。

核心代码

 1         /// <summary>
 2         /// 上传文件
 3         /// </summary>
 4         /// <param name="serverReleativeUrl">文件夹的相对路径</param>
 5         /// <param name="fileName"></param>
 6         /// <returns></returns>
 7         public string UploadFile(string serverReleativeUrl, string fileName, byte[] data, bool bOverWrite)
 8         {
 9             if (data.Length == 0)
10             {
11                 return string.Empty.ToErrorJson("500", "不允许上传空文件");
12             }
13             if (string.IsNullOrEmpty(this._siteInfo.UserName))
14             {
15                 return string.Empty.ToErrorJson("500", new ArgumentNullException("用户名参数为空").Message);
16             }
17             ClientContext spContext = new ClientContext(this._siteInfo.AppUrl);
18             //spContext.Credentials = new NetworkCredential(this._userName, this._pwd, this.strDomain);
19             /*
20            * SSL 支持
21            * SSL 身份验证协议依赖于证书。.
22            * NET Framework 中对 SSL 的支持包含两个部分。
23            * HTTP 上的 SSL 这种特殊情况(但使用最为广泛)由 HttpWebRequest 类(它最终还可用于 Web 服务客户端代理)实现。
24            * 要启用 SSL,除了要指定一个使用 Https: 协议的 URL 外,不必执行任何特殊操作。
25            * 当连接到一个受 SSL 保护的终结点时,会在客户端上对服务器证书进行验证。
26            * 如果验证失败,连接会根据默认设置立即关闭。您可以回调一个名为 ServicePointManager 的类来重写该行为。
27            * 每当 HTTP 客户端的堆栈进行证书验证时,都会首先检查是否可以回调;
28            * 如果可以,则执行您的代码。要挂接该回调,您必须提供类型 RemoteCertificateValidationCallback 的一个委托:
29            */
30             ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(VerifyServerCertificate);
31
32             spContext.ExecutingWebRequest += spContext_ExecutingWebRequest;
33             Web website = spContext.Web;
34             Folder folder = website.GetFolderByServerRelativeUrl(serverReleativeUrl);
35             try
36             {
37                 FileCreationInformation file = new FileCreationInformation();
38                 file.Content = data;
39                 file.Url = fileName;
40                 file.Overwrite = bOverWrite;
41                 folder.Files.Add(file);
42                 spContext.ExecuteQuery();
43             }
44             catch (Exception ex)
45             {
46                 throw ex;
47             }
48
49             return string.Empty.ToSuccessJson("200", "上传成功");
50         }
51         /// <summary>
52         /// 在回调中,您会获得服务器证书、一个错误代码和一个传入的链对象,然后可以执行自己的检查并返回 true 或 false。
53         /// 如果出现诸如证书在开发或测试期间就已过期的情况,那么关闭其中某项检查是有好处的。另一方面,这样做还可以执行比默认更为严格的验证策略。
54         /// https://msdn.microsoft.com/zh-cn/magazine/cc163454.aspx#S6
55         /// </summary>
56         /// <param name="sender"></param>
57         /// <param name="certificate"></param>
58         /// <param name="chain"></param>
59         /// <param name="sslPolicyErrors"></param>
60         /// <returns></returns>
61         private bool VerifyServerCertificate(object sender, X509Certificate certificate,
62     X509Chain chain, SslPolicyErrors sslPolicyErrors)
63         {
64             if (sslPolicyErrors == SslPolicyErrors.None) return true;
65
66             foreach (X509ChainStatus s in chain.ChainStatus)
67             {
68                 // allows expired certificates
69                 if (string.Equals(s.Status.ToString(), "NotTimeValid",
70                     StringComparison.OrdinalIgnoreCase))
71                     return true;
72             }
73
74             return false;
75         }
76         void spContext_ExecutingWebRequest(object sender, WebRequestEventArgs e)
77         {
78             HttpWebRequest webReq = e.WebRequestExecutor.WebRequest;
79             #region 此种方式个人的能上传,团队的不能上传
80             //string pfxPath = ConfigurationManager.AppSettings["ClientSigningCertificatePath"];
81             //string pfxPassword = ConfigurationManager.AppSettings["ClientSigningCertificatePassword"];
82             //X509Certificate2 cert = new X509Certificate2(pfxPath, pfxPassword);
83             //webReq.Credentials = new NetworkCredential(this._userName, _pwd, strDomain);
84             //webReq.ClientCertificates.Add(cert);
85             #endregion
86             CheckAppExsit();
87             var accessToken = TokenHelper.GetS2SAccessTokenWithWindowsIdentity(new Uri(_siteInfo.AppUrl), null);
88             webReq.Method = "Post";
89             webReq.Accept = "application/json;odata=verbose";
90             webReq.Headers.Add("Authorization", "Bearer " + accessToken);
91         }

这种方式,可以直接使用证书进行认证,而不用提供账户信息。这里提供一下思路,希望对你有所帮助。

总结

在sharepoint中上传文件,采用Client object model是相对rest api更简单的一种方式,采用rest api,我是没有成功过,也不知道那地方出问题了,很是头疼,最后没办法,采用了这种方式。

参考文章:

http://blog.csdn.net/starlee/article/details/4441150

https://msdn.microsoft.com/zh-cn/magazine/cc163454.aspx#S6

http://www.cnblogs.com/dosboy/p/4045773.html

时间: 2024-10-05 14:25:39

WebHttpRequest在sharepoint文档库中的使用的相关文章

CAML获取SharePoint文档库中除文件夹外所有文档

方法一: ? 1 2 3 4 <QueryOptions>         <ViewAttributes Scope="Recursive" />     </QueryOptions> </query> 方法二: ? 1 2 3 4 5 <View Scope="RecursiveAll">     <Query>         <Where>...</Where>

sharepoint文档库中日期显示详细日期,不显示几天前

文档库---库设置----栏

SharePoint 2013 文档库中PPT转换PDF

原文:SharePoint 2013 文档库中PPT转换PDF 通过使用 PowerPoint Automation Services,可以从 PowerPoint 二进制文件格式 (.ppt) 和 PowerPoint Open XML 文件格式 (.pptx) 转换为其他格式.例如,您可能需要将一批 PowerPoint 97–2003 文件升级到 Open XML 演示文稿文件.您还可以在“编辑”菜单中创建自定义操作,以允许用户按需创建 PDF 版本的演示文稿. 一.效果演示: 1.新建一

查看SharePoint文档库是,显示层次目录,可以点击返回层次

在sharepoint 2013中,Documnet library(文档库)包含多层文件夹,当进入到文件夹后,返回指定层次了(例如返回上一层),需要用浏览器的返回. 使用起来不方便,而且浏览器的返回,会导致一些问题,不推荐普遍用户使用. 解决这个问题,可以做一个目录结构,实现方法是:访问Document library 时, url 有个参数[RootFolder],记录了路径. 主要对[RootFolder]参数进行处理. 这里使用webpart实现.当然,也可以Javascript方式实现

解决SharePoint 文档库itemadded eventhandler导致的上传完成后,编辑页面保持报错的问题,错误信息为“该文档已经被编辑过 the file has been modified by...”

在文档库中添加itemadded 后,在上传文件后,会自动打开文档属性的编辑页面,在保存的时候就会报错,说这个文档已经被编辑过了.这是应为默认itemadded实践是异步执行的,会在edit页面打开之前就把属性更新完了,知道在保存的时候,属性不一致. 两种解决方法: 1: 使用item.sysupdate(false). 这个false参数非常重要. 2:将handler的执行变为非异步执行,编辑element.xml文件,如下红色部分: <Receiver><Name>AutoD

可视化webpart基础开发——TreeView控件读取文档库中的所有文件夹和文件(递归方法读取)

可视化webpart基础开发——TreeView控件读取文档库中的所有文件夹和文件(递归方法读取) 分类: SharePoint2011-12-23 14:44 1584人阅读 评论(0) 收藏 举报 文档sharepointurl测试stringforms 可视化webpart基础开发——TreeView控件读取文档库中的所有文件夹和文件(递归方法读取) 1.在部署的sharepoint网站中新建一个名为“测试文档库”的文档库,并添加各级的子文件夹和子文件,用于测试 2.在VS2010中新建空

代码操作Sharepoint文档库(创建、上传附件)

代码操作Sharepoint文档库(创建.上传附件) 做项目中遇到客户需求,根据Infopath表单生成Excel并上传到Sharepoint指定文档库中 创建文档库 SPSite site = new SPSite(siteurl); SPListItem item = site.AllWebs["网站名"].Lists["列表名"].Folders.Add("文档库URL", SPFileSystemObjectType.Folder); i

[sharepoint]文档库,文件夹授权

写在前面 在项目中用到了文档库授权的方法,这里将查询到的方式总结一下. 涉及到的方法 在逻辑中用到的方法. /// <summary> /// 获取sharepoint站点角色定义 rest api /// </summary> /// <param name="hostWebUrl"></param> /// <param name="strAPI"></param> /// <para

通过webService下载sharepoint文档库文件

第一.基本原理: 1.通过对象模型得到SPItem.File得到文档库文件 2.通过WebService将item.File.OpenBinary()返回 3.将文件保存到服务器 4.从服务器下载到本地 第二.具体代码: WebService [WebMethod] public byte[] GetAttachmentFileflow(string webPath,string list,int fileId) { try { using (SPSite site = new SPSite(w