我有一个从 HTTP 请求解析 XML 响应的例程,我使用 XmlDocument.LoadXml 来帮助执行此操作。我指望这种方法在错误的 XML 上引发异常并在成功时返回加载的 XmlDocument 对象。
我没想到的是它在加载文档时会挂起几分钟。当我在测试环境中运行此代码时,它 100% 的时间会挂起几分钟。对我来说,这看起来像是 .NET 中的一些错误......
Dim tstring As String = ""
tstring &= "" & vbCrLf
tstring &= "" & vbCrLf
tstring &= "<!DOCTYPE html PUBLIC ""-//W3C//DTD XHTML 1.0 Transitional//EN"" ""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"">" & vbCrLf
tstring &= "" & vbCrLf
tstring &= "<html> xmlns=""http://www.w3.org/1999/xhtml"" >" & vbCrLf
tstring &= "<head><title>" & vbCrLf
tstring &= " Error" & vbCrLf
tstring &= "</title></head>" & vbCrLf
tstring &= "<body>" & vbCrLf
tstring &= "</body>" & vbCrLf
tstring &= "</html>" & vbCrLf
Dim MyXmlDoc As New XmlDocument
MyXmlDoc.LoadXml(tstring)
文档中可以删除以防止其挂起的特定行是:
tstring &= "<!DOCTYPE html PUBLIC ""-//W3C//DTD XHTML 1.0 Transitional//EN"" ""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"">" & vbCrLf
如果我看到它,我是否必须在字符串中搜索“<!DOCTYPE html”而不调用 LoadXml()?我对此的担忧是在这个方法中还有什么其他问题在等着我?