我需要编写一个创建FM XML文件的Web服务。
预期的输出文件如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<FMPXMLRESULT xmlns="http://www.filemaker.com/fmpxmlresult">
<ERRORCODE>0</ERRORCODE>
<PRODUCT BUILD="27/11/2002" NAME="FileMaker Pro" VERSION="6.0Dv4"/>
<DATABASE DATEFORMAT="d.M.yyyy" LAYOUT="" NAME="Schlüssel Adresse für green" RECORDS="3" TIMEFORMAT="k:mm:ss"/>
<METADATA>
<FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Datum" TYPE="DATE"/>
<FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Sprache Typ" TYPE="TEXT"/>
...
</METADATA>
<RESULTSET FOUND="3">
<ROW MODID="0" RECORDID="1">
<COL>
<DATA>12.11.2012</DATA>
</COL>
...
</ROW>
</RESULTSET>
</FMPXMLRESULT>
这是我的PHP代码:
$xml = new SimpleXMLElement('<FMPXMLRESULT xmlns="http://www.filemaker.com/fmpxmlresult"></FMPXMLRESULT>');
$xml->addChild('ERRORCODE',0);
$xml->addChild('PRODUCT BUILD="27/11/2002" NAME="FileMaker Pro" VERSION="6.0Dv4"');
$xml->addChild('DATABASE DATEFORMAT="d.M.yyyy" LAYOUT=" " NAME="Schlüssel Adresse für green" RECORDS="3" TIMEFORMAT="k mm ss" ');
$node = $xml->addChild('METADATA');
$node->addChild('FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Datum" TYPE="DATE"');
$node->addChild('FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Sprache Typ" TYPE="TEXT"');
...
$node = $xml->addChild('RESULTSET FOUND="3"');
$node->addChild('FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Datum" TYPE="DATE"');
有两件事我无法开展工作:
DATABASE节点中的TIMEFORMAT =“k:mm:ss”会引发以下错误。删除冒号':'解决了错误消息问题,但不会生成相同的文件
第80行第2行的错误:解析属性名称时出错
只要在结果中有'FOUND =“3”'和一个子节点,RESULTSET节点就会引发错误。如果没有孩子,它不会导致任何错误。如果删除FOUND =“3”,则没有错误。
此页面包含以下错误:
第2199行第2行的错误:预期'&gt;'
非常感谢任何帮助!
答案 0 :(得分:1)
使用
解决了这两种情况 $node->addAttribute("...","...")