看起来我们没有XML文档


looks like we got no XML document

我在使用SOAP和PHP时遇到了一些奇怪的问题。相同的函数适用于小数据,但当我的查询返回超过X行时,会导致异常"Uncaught SoapFault异常:[Client]看起来没有XML文档"。

这是我的代码:

<?php
$cliente = new SoapClient(null, array('location' => $myserver,'uri' => 'urn:webservices'));
?>
<select id="actividad" name="actividad" size="1" style="height:40px; width: 100%;">
<?php
$acs = $cliente->get_actividades();
foreach($acs as $actividad) {
echo "<option value='".$actividad['idactividad']."'>".$actividad['descripcion']."</option>";
}                                       
?>
</select>

这是服务器端:

public function get_actividades()
{
    $link = new mysqli($this->dbhost,$this->dbuser,$this->dbpass,$this->dbname);
    if (mysqli_connect_errno()) {
        return 0;
    }
    $query = "SELECT idactividad, codigo, descripcion FROM actividades";
    $datos = array();
    if ($stmt = $link->prepare($query)) {
        $stmt->execute();
        $stmt->store_result();
        $datos = $this->fetcharray($stmt);
        $stmt->free_result();
        $stmt->close();
        return $datos;
    } else { 
        return -1; 
    }           
}

该查询结果大约有37行。如果我在1到21行之间的查询中添加一个"LIMIT"子句,它可以很好地工作,但更重要的是会导致无xml异常。

可能是内存问题吗??我能给谁修?

您必须回显它,而不是像以前那样返回值。例如,如果回显$datos,它仍然无法工作,因为您需要显示符合SOAP的XML文档。您需要处理该行数组,以便将它们转换为XML文档。

字节顺序标记(BOM)与php标记前的空白具有相同的效果。在这里,您可以找到一个PHP片段来检测和删除BOM。请确保将编辑器配置为不再插入BOM表。