我一直在使用以下代码从Sharepoint(在Office 365上)获取文件夹和文件列表…
...
var folders = ListFolders(libraryName, clientContext, web);
...
public List<Folder> ListFolders(string libraryName, ClientContext clientContext, Web web)
{
var list = GetDocumentLibrary(libraryName, clientContext, web);
var folders = list.RootFolder.Folders;
clientContext.Load(folders);
clientContext.ExecuteQuery();
return folders.ToList();
}
public List GetDocumentLibrary(string libraryName, ClientContext clientContext, Web web)
{
var query = clientContext.LoadQuery(web.Lists.Where(p => p.Title == libraryName));
clientContext.ExecuteQuery();
return query.FirstOrDefault();
}
它工作正常,直到我重新启动我的计算机(它安装了Windows Update),我强烈怀疑,基于我已经完成的一些测试,这似乎是由http://support.microsoft.com/kb/2964358引起的.
当在GetDocumentLibrary()中到达clientContext.ExecuteQuery()语句时,
抛出以下异常.
System.Xml.dll中发生了未处理的“System.Xml.XmlException”类型异常
附加信息:出于安全原因,此XML文档中禁止使用DTD.要启用DTD处理,请将XmlReaderSettings上的DtdProcessing属性设置为Parse,并将设置传递给XmlReader.Create方法.
我想知道如何解决这个问题,因为我没有有意识地使用System.XML,它是ExecuteQuery运行时的后台函数或进程.
我可以将一些额外的XMLReader信息传递给this或clientContext(我假设没有),所以我不确定如何执行此查询以防止DTD错误.我也尝试使用此代码以不同的方式访问列表…(来自Microsoft的MSDN页面)
List list = clientContext.Web.Lists.GetByTitle(libraryName);
CamlQuery camlQuery = new CamlQuery();
camlQuery.ViewXml = "<View/>";
ListItemCollection listItems = list.GetItems(camlQuery);
clientContext.Load(list); clientContext.Load(listItems);
clientContext.ExecuteQuery();
这可以在没有上面的KB的计算机上工作,但是在我的电脑上它不会(我得到与我的其他代码相同的例外),显然卸载KB会使事情在短期内起作用,但是在较长时间内它没有好处术语.任何关于如何避免此错误的建议将不胜感激.我只能假设现在这个KB已经实现,将有一种来自Microsoft的“首选”方式来访问列表,但我对它是什么一无所知.
谢谢
Dougie
最佳答案 我使用第二个路由器作为WiFi扩展器,这似乎有一个奇怪但可重现的效果连接到sharepoint时,我停止使用它并使用我的主路由器/ wifi盒,我的问题消失了.