我是 SharePoint 的新手,在引用 url - 使用客户端对象模型联机访问 SharePoint - 禁止错误后,我成功地连接到 sharepoint 并在控制台应用程序 C# 中检索详细信息。我的问题是当我将相同的代码移动到 asp.net 网站时,它给了我集合尚未初始化错误。这是代码
using (ClientContext clientContext = new ClientContext("https://.../sites/.../"))
{
SecureString passWord = new SecureString();
foreach (char c in "abcdefghijklmnop".ToCharArray()) passWord.AppendChar(c);
clientContext.Credentials = new SharePointOnlineCredentials("myname@mydomain.com", passWord);
List list = clientContext.Web.Lists.GetByTitle("ABC DEF");
CamlQuery camlQuery = new CamlQuery();
camlQuery.ViewXml = "<View><RowLimit>1200</RowLimit></View>";
ListItemCollection collListItem = list.GetItems(camlQuery);
clientContext.Load(collListItem, li => li.Include(
pi => pi.Id,
pi => pi["Title"],
pi => pi["Application"],
pi => pi["URL"],
pi => pi["AIR_x0020_ID"]
));
clientContext.ExecuteQuery();
List<string> listofapplications = new List<string>();
foreach (ListItem oListItem in collListItem)
{
{ Console.WriteLine(oListItem["Title"] + ", Application " + oListItem["Application"]); }
}
Console.ReadLine();
}
它给了我错误 foreach(列表项 o列表项 在 collListItem 中(:
类型为"Microsoft.SharePoint.Client.CollectionNotInitializedException"的异常 发生在 Microsoft.SharePoint.Client.Runtime.dll但没有 在用户代码中处理
其他信息:集合尚未初始化。它 尚未请求或请求尚未执行。它可能会 需要明确请求。
这是详细的错误:
Microsoft.SharePoint.Client.CollectionNotInitializedException is 未由用户代码处理 HResult=-2146233079 消息=集合 尚未初始化。尚未请求或请求已请求 未执行。可能需要明确请求。
Source=Microsoft.SharePoint.Client.Runtime StackTrace: at Microsoft.SharePoint.Client.ClientObjectCollection'1.d__0.MoveNext(( at Home.btn_Click(Object sender, EventArgs e( in c:\Users\rakesh.a.srivastava\Documents\Visual Studio 2015\网站\DNSProvisioningPortal\首页.aspx.cs:第45行 at System.Web.UI.WebControls.Button.OnClick(EventArgs e( at System.Web.UI.WebControls.Button.RaisePostBackEvent(String eventArgument( at System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String 事件参数( at System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument( at System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData( at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint(
InnerException:
请注意,我在控制台应用程序中没有任何问题,但 asp.net 按钮单击操作。我还添加了客户端和客户端运行时引用!我无法理解为什么它在控制台中有效,但在网站上不起作用。我是否缺少任何命名空间,引用?我引用了这些 URL 集合尚未初始化,SharePoint 字段尚未在 C# 中初始化,SharePoint 客户端对象模型 属性或字段尚未初始化,但没有任何关于我的问题的信息。请帮忙。谢谢
根据我的测试,有时我们可以忽略 aspnet 项目中的异常。(对于您的代码,您需要将 ["XXX"] 替换为 Client_XXX(
制备
通过 NuGet 包管理器安装Microsoft.SharePointOnline.CSOM到项目。
我的测试代码: 首先是扩展方法(可选(
public static class CSOMExtensions
{
public static Task ExecuteQueryAsync(this ClientContext clientContext)
{
return Task.Factory.StartNew(() =>
{
clientContext.ExecuteQuery();
});
}
}
用我的替换您帖子中的一些代码:
List list = clientContext.Web.Lists.GetByTitle("CustomList1");
CamlQuery camlQuery = new CamlQuery();
camlQuery.ViewXml = "<View><RowLimit>1200</RowLimit></View>";
ListItemCollection collListItem = list.GetItems(camlQuery);
clientContext.Load(collListItem, li => li.Include(
pi => pi.Client_Title
//pi => pi["Application"],
// pi => pi["AIR_x0020_ID"]
));
//clientContext.ExecuteQueryAsync();
Task t2 = clientContext.ExecuteQueryAsync();
await t2.ContinueWith((t) =>
{
foreach (ListItem oListItem in collListItem)
{
System.Diagnostics.Debug.WriteLine(oListItem.Client_Title);
}
});
如果我们直接使用 ["标题"],它会在 aspnet 中崩溃,但Client_XXX不会在我这边。
我没有更深入的研究为什么,也没有尝试自定义字段。我会在有时间的时候研究更多