XML错误在PHP中编程时,对于属性“value”,需要打开引号

时间:2012-09-13 18:09:57

标签: php xml zoho

您好,感谢您的帮助,

我正在使用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>

2 个答案:

答案 0 :(得分:2)

您需要围绕value属性的实际值引用,如下所示:

<field name='Serial_Number' compOperator='Equals' value='{$MREPSerial}'></field>

答案 1 :(得分:0)

刚刚看到您的";关闭代码...

尝试使用该行

 <field name='Serial_Number' compOperator='Equals' value='".$MREPSerial."'></field>