![](/img/trans.png)
[英]XDocument Error Name cannot begin with the '<' character, hexadecimal value 0x3C
[英]Name cannot begin with the '<' character hexadecimal value 0x3c
我正在尝试使用 SOAP 请求从 WebService 获取一些数据。 SOAP 主体应包含 SQL 查询。 每当我使用<
字符时,它都会导致SOAPReqBody.LoadXml()
出现上述错误。 我怎样才能解决这个问题?
HttpWebRequest request = CreateSOAPWebRequest();
XmlDocument SOAPReqBody = new XmlDocument();
SOAPReqBody.LoadXml(@"<?xml version=""1.0"" encoding=""utf-8""?>
<soap:Envelope xmlns:xsi=""http://www.w3.org/2001/XMLSchema-instance"" xmlns:xsd=""http://www.w3.org/2001/XMLSchema"" xmlns:soap=""http://schemas.xmlsoap.org/soap/envelope/"">
<soap:Body>
<Query xmlns=""http://LifaOIS.DK/OISService"">
<UID>" + uid + @"</UID>
<PWD>" + pwd + @"</PWD>
<SQL>" + sql + @"</SQL>
<Meta>" + meta + @"</Meta>
</Query>
</soap:Body>
</soap:Envelope>");
这很难看,但是如果您确实必须在消息有效负载中携带 SQL 查询,并且小于“<”字符是 XML 中的问题并且您无法控制有效负载的打包和解包,那么您可能需要考虑使用之间...
WHERE field NOT EQUAL minValue AND field BETWEEN minvalue AND upperValue
请注意,BETWEEN 的 from 和 to 值是包容性的 - 因此需要排除 minValue
您是否尝试将sql
包装在<.[CDATA[...]]>
中?
喜欢:
<SQL><![CDATA[" + sql + @"]]></SQL>
代替
<SQL>" + sql + @"</SQL>
请参阅XML 中的 <?[CDATA[]]> 是什么意思? 更多细节。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.