nuSoap webservice服务器不返回mysql查询

时间:2015-05-16 14:54:18

标签: php mysql web-services nusoap

我正在尝试在我的webservice上返回一个mysql_query,但同样如此 获取数据但返回一个空数组。

我正在尝试获取类似的数据:

array(
0=>array('id'=>int,'nome'=>string,'voltagem'=>int, 'potencia'=>doube, 'standby'=>doube)
);
<?php
include("/lib/nusoap.php");


$servidor = new soap_server();

$servidor->configureWSDL("urn:Servidor");
$servidor->wsdl->schemaTargetNamespace = "urn:Servidor";


$servidor->wsdl->addComplexType(
  'produto',
  'complexType',
  'struct',
  'all',
  '',
array(
    'id'       => array('name'=>'id',      'type'=>'xsd:int'),
    'nome'     => array('name'=>'nome',    'type'=>'xsd:string'),
    'voltagem' => array('name'=>'voltagem','type'=>'xsd:int'),
    'potencia' => array('name'=>'potencia','type'=>'xsd:int'),
    'standby'  => array('name'=>'standby', 'type'=>'xsd:int')
)
);

$servidor->register( 'buscar',
  array('produtonome'=>'xsd:string'),
  array('retorno'=>'tns:produto'),
  'urn:Servidor.buscar',
  'urn:Servidor.buscar',
  'rpc',
  'econded',
  'apenas um exemplo usando o nuSuop PHP'
  );

function buscar($produtonome){
    $db = new mysqli('localhost', 'root', '', 'produto');

    if($db->connect_errno > 0){
        die('Unable to connect to database [' . $db->connect_error . ']');
    }


$sql = <<<SQL SELECT * FROM `produto` LIMIT 1 SQL;

    if(!$result = $db->query($sql)){
        die('There was an error running the query [' . $db->error . ']');
    }
    while($row = $result->fetch_assoc()){

        $dados['id']       = $row['id'];
        $dados['nome']     = $row['nome'];
        $dados['voltagem'] = $row['voltagem'];
        $dados['potencia'] = $row['potencia'];
        $dados['standby']  = $row['standby'];    
    }
}


$HTTP_RAW_POST_DATA = (isset($HTTP_RAW_POST_DATA) ? $HTTP_RAW_POST_DATA : 'teste');

$servidor->service($HTTP_RAW_POST_DATA);
?>

1 个答案:

答案 0 :(得分:0)

经过几个小时的尝试,我决定用json返回搜索。其他人在没有成功的情况下也有同样的错误。肥皂上的一些错误