繁体   English   中英

名称不能以 '<' 字符十六进制值 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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM