php soap 错误 “looks like we got no XML document”
今天在想使用soap开发相关接口给合作的公司调用,但是遇到了这个错误。排查了很久,在google也查了很久,但都不是我所遇到的问题。不过我最终错误发现跟soapserver传输的数据量的大小有关系(不知道这个描述是否恰当)。当我从数据库取10条数据,那么就可以很容易的使用soapclient获取到数据,但是当我从数据库里查询1000条数据的时候就会报错了(“Fatal error: Uncaught SoapFault exception: [Client] looks like we got no XML document in……”)!如果我直接运行person.class.php程序是可以显示完整的xml文档的。这根服务器的环境配置会有关系吗?我对于soap认识并不深,也只是现学现卖。希望有经验的前辈们可以指点一二。多谢了!
以下是我的程序代码:
<?php //person.class.php文件 class person { public function getInfo() { $strGetList = 'SELECT * FROM information LIMIT 100'; $GLOBALS['le']->query($strGetList); $results = array(); $xmlString = "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"; $xmlString .="<Data>\n"; while( $rows = $GLOBALS['le']->fetch_assoc() ) { $results[] = $rows; } foreach($results as $key=>$val) { $xmlString .="<Rec ID='UU{$key}'>\n"; foreach($val as $k=>$v ) { if(strlen($v)>0) { $v = htmlspecialchars($v); $xmlString .=" <UU{$k}>$v</UU{$k}>\n"; } } $xmlString .="</Rec>\n"; } $xmlString .="</Data>\n"; return $xmlString; } } //$p = new person; //echo $p->getInfo();//经测试xml中可以显示所有数据 --- 分割线 --- <?php //server.php文件 include("person.class.php"); $server = new SoapServer(null,array('uri'=>'abcd','encoding'=>'UTF-8')); $server->setClass('person'); $server->handle(); --- 分割线 --- <?php //client.php文件 try{ $soap = new SoapClient(null,array( 'location'=>'http://192.168.1.126:102/server.php', 'uri'=>'abcd', 'encoding' => 'UTF-8', )); $s1 =$soap->__soapCall('getInfo',array()); echo $s1; } catch(Exction $e) { echo $e->getMessage(); }
xelless
11 years, 8 months ago
Answers
从SoapClient的异常"[Client] looks like we got no XML document"来看应该是响应有问题,所以首要的是查看响应消息是什么,有几种方案可以协助你定位问题:
- 简单一点的,你可以用 SoapUI ,查看响应是否真的有问题?是否没有响应?
- Geek一点的,自制一个模拟客户端来检查响应消息,普通的SOAP协议并不难,只需用HTTP协议POST一小段XML给Server就行,代码量应该在20行以内
- 我平时常用一点的,因为SOAP是走HTTP传输协议的,因此可以抓取整个HTTP Response,检查其内容是否符合XML格式。抓取方式可以用 tcpdump (Linux命令行)或 HTTPTracer (Java跨平台,使用方便,我的最爱)
- 直接一点的,查看SoapClient.php的源码,我没记错的话代码量挺小的,查找字符串“looks like we got no XML document”,然后往回找到XML解析那段,在解析前输出原始内容看看到底响应内容出现了什么问题
夏天刨西瓜
answered 11 years, 8 months ago