c# – 访问sharepoint 2013 / office365列表时出现“DTD被禁止”错误(但未公开了解使用XML)

我一直在使用以下代码从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盒,我的问题消失了.

点赞