您好,感谢您的帮助,
我正在使用PHP编写XML请求,我遇到的问题是当我在值字段中使用变量时,它会返回错误。但是,当我手动写入值时,它可以完美地工作。 在字段名称='Serial_Number'下,您将看到$ MREPSerial是变量,让我们假设 在PHP中我们有$ MREPSerial ='A-000-1042';以下XML会出错。但是,如果我只用XML中的值替换$ MREPSerial它就会成功。任何帮助将不胜感激。谢谢!
$MREPSerial = htmlspecialchars(strtoupper($_POST['NSMREP']));
echo "Hi".$MREPSerial;
<ZohoCreator>
<applicationlist>
<application name='ajout-de-materiel'>
<formlist>
<form name='MREP'>
<update>
<criteria>
<field name='Serial_Number' compOperator='Equals' value={$MREPSerial}></field>
<reloperator>AND</reloperator>
<field name='MREP_Type' compOperator='Equals' value='0'></field>
</criteria>
<newvalues>
<field name='Is_being_Used' value='TRUE'></field>
</newvalues>
</update>
</form>
</formlist>
</application>
</applicationlist>
</ZohoCreator>";
... echo的返回响应(包括我回应的XML)
A-000-1012HI! <?xml version="1.0" encoding="UTF-8" ?>
<response><errorlist><error><code>2830</code><message><![CDATA[Open quote is expected for attribute "value" associated with an element type "field".]]></message></error></errorlist></response>
如果我将它改为“”,则返回echo的响应。$ MREPSerial。“是:
A-000-1012HI! <?xml version="1.0" encoding="UTF-8" ?>
<response><result><form name="MREP"><update><criteria><field name="Serial_Number" compOperator="Equals" value=""></field><reloperator>AND</reloperator><field name="MREP_Type" compOperator="Equals" value="0"></field></criteria><newvalues><field name="Is_being_Used"><value><![CDATA[TRUE]]></value></field></newvalues> <status>Failure, No Records Found With Specified Criteria</status></update></form></result></response>
答案 0 :(得分:2)
您需要围绕value属性的实际值引用,如下所示:
<field name='Serial_Number' compOperator='Equals' value='{$MREPSerial}'></field>
答案 1 :(得分:0)
刚刚看到您的";
关闭代码...
尝试使用该行
<field name='Serial_Number' compOperator='Equals' value='".$MREPSerial."'></field>