如何使用 CSOM 将(多个)文件上传到 SharePoint Online?
How to upload (multiple) files to SharePoint Online using CSOM?
我有一个 Web 表单,可以将一些输入的数据作为新列表项上传到 SharePoint 列表,效果很好。我尝试添加一个新代码以通过两个单独的 <asp:FileUpload>
控件上传两个文件。 protected void sendToSharePoint() {}
中的以下代码无法将任何一个文件上传到指定的 SharePoint 文档库,更不用说两者了:
Default.aspx:
//Existing code
<asp:FileUpload ID="upldGradeReport" runat="server" />
<asp:FileUpload ID="upldExpenseReceipt" runat="server" />
<asp:Button ID="btnSubmitForm" OnClick="SubmitButton_Click" runat="server" Text="Submit" />
Default.aspx.cs:
using System;
using System.DirectoryServices;
using System.IO;
using System.Security;
using System.Web.UI;
using Microsoft.SharePoint.Client;
using ClientOM = Microsoft.SharePoint.Client;
//I left out the NameSpace and default public partial class wrapper, but they're here.
public ClientContext SPClientContext { get; set; }
public string SPErrorMsg { get; set; }
protected void SubmitButton_Click(object sender, EventArgs e) {
sendToSharePoint();
Response.BufferOutput = true;
Response.Redirect("Submission.aspx");
}
protected void sendToSharePoint() {
try {
string siteUrl = "<sharepoint site url>";
ClientContext clientContext = new ClientContext(siteUrl);
clientContext.Credentials = new SharePointOnlineCredentials("<my username>", "<my password>");
string sDocName = string.Empty;
string sDocName1 = string.Empty;
Uri uri = new Uri(siteUrl);
string sSPSiteRelativeURL = uri.AbsolutePath;
sDocName = UploadFile(upldGradeReport.FileContent, upldGradeReport.FileName, sSPSiteRelativeURL, "<sharepoint document library>");
sDocName1 = UploadFile(upldExpenseReceipt.FileContent, upldExpenseReceipt.FileName, sSPSiteRelativeURL, "<sharepoint document library>");
//prior CSOM code to insert values into a new List Item exists here
clientContext.ExecuteQuery();
} catch (Exception ex) {
String ThisError = ex.Message;
}
}
public String UploadFile(Stream fs, string sFileName, string sSPSiteRelativeURL, string sLibraryName) {
string sDocName = string.Empty;
try {
var sFileURL = String.Format("{0}/{1}/{2}", sSPSiteRelativeURL, sLibraryName, sFileName);
ClientOM.File.SaveBinaryDirect(SPClientContext, sFileURL, fs, true);
sDocName = sFileName;
} catch (Exception ex) {
sDocName = string.Empty;
SPErrorMsg = ex.Message;
}
return sDocName;
}
创建新 ListItem 并将表单的其余输入数据上传到单独的 SharePoint 列表的代码在提交后仍然有效,我已确认凭据正确并且正在使用的帐户有权将文件上传到文档库。
我做错了什么?
我在本地环境中测试了以下代码;它工作正常。
<div>
<asp:FileUpload ID="upldGradeReport" runat="server" />
<asp:FileUpload ID="upldExpenseReceipt" runat="server" />
<asp:Button ID="btnSubmitForm" OnClick="SubmitButton_Click" runat="server" Text="Submit" />
</div>
protected void SubmitButton_Click(object sender, EventArgs e)
{
sendToSharePoint();
Response.BufferOutput = true;
Response.Redirect("Submission.aspx");
}
protected void sendToSharePoint()
{
try
{
string siteUrl = "https://tenant.sharepoint.com/sites/lee";
ClientContext clientContext = new ClientContext(siteUrl);
SecureString securePassword = new SecureString();
foreach (char c in "password".ToCharArray()) securePassword.AppendChar(c);
clientContext.Credentials = new SharePointOnlineCredentials("lee@tenant.onmicrosoft.com", securePassword);
string sDocName = string.Empty;
string sDocName1 = string.Empty;
Uri uri = new Uri(siteUrl);
string sSPSiteRelativeURL = uri.AbsolutePath;
sDocName = UploadFile(clientContext,upldGradeReport.FileContent, upldGradeReport.FileName, sSPSiteRelativeURL, "MyDoc");
sDocName1 = UploadFile(clientContext,upldExpenseReceipt.FileContent, upldExpenseReceipt.FileName, sSPSiteRelativeURL, "MyDoc");
//prior CSOM code to insert values into a new List Item exists here
//clientContext.ExecuteQuery();
}
catch (Exception ex)
{
String ThisError = ex.Message;
}
}
public String UploadFile(ClientContext clientContext,Stream fs, string sFileName, string sSPSiteRelativeURL, string sLibraryName)
{
string sDocName = string.Empty;
try
{
var sFileURL = String.Format("{0}/{1}/{2}", sSPSiteRelativeURL, sLibraryName, sFileName);
Microsoft.SharePoint.Client.File.SaveBinaryDirect(clientContext, sFileURL, fs, true);
sDocName = sFileName;
}
catch (Exception ex)
{
sDocName = string.Empty;
//SPErrorMsg = ex.Message;
}
return sDocName;
}
我有一个 Web 表单,可以将一些输入的数据作为新列表项上传到 SharePoint 列表,效果很好。我尝试添加一个新代码以通过两个单独的 <asp:FileUpload>
控件上传两个文件。 protected void sendToSharePoint() {}
中的以下代码无法将任何一个文件上传到指定的 SharePoint 文档库,更不用说两者了:
Default.aspx:
//Existing code
<asp:FileUpload ID="upldGradeReport" runat="server" />
<asp:FileUpload ID="upldExpenseReceipt" runat="server" />
<asp:Button ID="btnSubmitForm" OnClick="SubmitButton_Click" runat="server" Text="Submit" />
Default.aspx.cs:
using System;
using System.DirectoryServices;
using System.IO;
using System.Security;
using System.Web.UI;
using Microsoft.SharePoint.Client;
using ClientOM = Microsoft.SharePoint.Client;
//I left out the NameSpace and default public partial class wrapper, but they're here.
public ClientContext SPClientContext { get; set; }
public string SPErrorMsg { get; set; }
protected void SubmitButton_Click(object sender, EventArgs e) {
sendToSharePoint();
Response.BufferOutput = true;
Response.Redirect("Submission.aspx");
}
protected void sendToSharePoint() {
try {
string siteUrl = "<sharepoint site url>";
ClientContext clientContext = new ClientContext(siteUrl);
clientContext.Credentials = new SharePointOnlineCredentials("<my username>", "<my password>");
string sDocName = string.Empty;
string sDocName1 = string.Empty;
Uri uri = new Uri(siteUrl);
string sSPSiteRelativeURL = uri.AbsolutePath;
sDocName = UploadFile(upldGradeReport.FileContent, upldGradeReport.FileName, sSPSiteRelativeURL, "<sharepoint document library>");
sDocName1 = UploadFile(upldExpenseReceipt.FileContent, upldExpenseReceipt.FileName, sSPSiteRelativeURL, "<sharepoint document library>");
//prior CSOM code to insert values into a new List Item exists here
clientContext.ExecuteQuery();
} catch (Exception ex) {
String ThisError = ex.Message;
}
}
public String UploadFile(Stream fs, string sFileName, string sSPSiteRelativeURL, string sLibraryName) {
string sDocName = string.Empty;
try {
var sFileURL = String.Format("{0}/{1}/{2}", sSPSiteRelativeURL, sLibraryName, sFileName);
ClientOM.File.SaveBinaryDirect(SPClientContext, sFileURL, fs, true);
sDocName = sFileName;
} catch (Exception ex) {
sDocName = string.Empty;
SPErrorMsg = ex.Message;
}
return sDocName;
}
创建新 ListItem 并将表单的其余输入数据上传到单独的 SharePoint 列表的代码在提交后仍然有效,我已确认凭据正确并且正在使用的帐户有权将文件上传到文档库。
我做错了什么?
我在本地环境中测试了以下代码;它工作正常。
<div>
<asp:FileUpload ID="upldGradeReport" runat="server" />
<asp:FileUpload ID="upldExpenseReceipt" runat="server" />
<asp:Button ID="btnSubmitForm" OnClick="SubmitButton_Click" runat="server" Text="Submit" />
</div>
protected void SubmitButton_Click(object sender, EventArgs e)
{
sendToSharePoint();
Response.BufferOutput = true;
Response.Redirect("Submission.aspx");
}
protected void sendToSharePoint()
{
try
{
string siteUrl = "https://tenant.sharepoint.com/sites/lee";
ClientContext clientContext = new ClientContext(siteUrl);
SecureString securePassword = new SecureString();
foreach (char c in "password".ToCharArray()) securePassword.AppendChar(c);
clientContext.Credentials = new SharePointOnlineCredentials("lee@tenant.onmicrosoft.com", securePassword);
string sDocName = string.Empty;
string sDocName1 = string.Empty;
Uri uri = new Uri(siteUrl);
string sSPSiteRelativeURL = uri.AbsolutePath;
sDocName = UploadFile(clientContext,upldGradeReport.FileContent, upldGradeReport.FileName, sSPSiteRelativeURL, "MyDoc");
sDocName1 = UploadFile(clientContext,upldExpenseReceipt.FileContent, upldExpenseReceipt.FileName, sSPSiteRelativeURL, "MyDoc");
//prior CSOM code to insert values into a new List Item exists here
//clientContext.ExecuteQuery();
}
catch (Exception ex)
{
String ThisError = ex.Message;
}
}
public String UploadFile(ClientContext clientContext,Stream fs, string sFileName, string sSPSiteRelativeURL, string sLibraryName)
{
string sDocName = string.Empty;
try
{
var sFileURL = String.Format("{0}/{1}/{2}", sSPSiteRelativeURL, sLibraryName, sFileName);
Microsoft.SharePoint.Client.File.SaveBinaryDirect(clientContext, sFileURL, fs, true);
sDocName = sFileName;
}
catch (Exception ex)
{
sDocName = string.Empty;
//SPErrorMsg = ex.Message;
}
return sDocName;
}