| Author |  | 
| SUNJIB 
 
 
 Joined: 08 Jul 2010
 Posts: 8
 
 
 | 
|  Posted: Tue 03 Aug '10 8:13    Post subject: SOAP WebService not ABLE to return RESULT for > 40 Record |   |  
| 
 |  
| Hi Folks, 
 Can Anybody help me to figure out why the Webservice is not being able to return more than 40 records Aprox?
 
 I am writing this for a GROWING TABLE, which has twenty thousand records presently.
 
 Is there any Size LIMIT for RESPONSE??
 
 Thanks in Advance
 
 SUNJIB MOHANTY
 0955 630 8008
 
 My Code:
 
 soap-client.php
 <?php
 $client = new SoapClient("catalog.wsdl");
 $catalogid=$_GET['catalogid'];
 $response = $client->getCatalogEntry($catalogid);
 //echo $response;
 ?>
 
 
 soap-server.php
 <?php
 function getCatalogEntry($catalogid)
 {
 if($catalogid=='3')
 {
 if(!$dbconnect = mysql_connect('localhost', 'root', 'pass'))
 {
 echo "Connection failed to the host 'localhost'.";
 exit;
 } // if
 if (!mysql_select_db('test')) {
 echo "Cannot connect to database 'test'";
 exit;
 } // if
 else
 {
 
 $table_id = 'antibody';
 $query = "SELECT * FROM antibody";
 $dbresult = mysql_query($query, $dbconnect);
 
 // create a new XML document
 $doc = new DomDocument('1.0');
 //echo "XML Dome is created";
 
 // create root node
 $root = $doc->createElement('root');
 $root = $doc->appendChild($root);
 
 
 while($row = mysql_fetch_array($dbresult, MYSQL_ASSOC))
 {
 $occ = $doc->createElement($table_id);
 $occ = $root->appendChild($occ);
 // add a child node for each field
 foreach ($row as $fieldname => $fieldvalue)
 {
 $child = $doc->createElement($fieldname);
 $child = $occ->appendChild($child);
 
 $value = $doc->createTextNode($fieldvalue);
 $value = $child->appendChild($value);
 } // foreach
 }
 
 // get completed xml document
 $xml_string = $doc->saveXML();
 }
 return $xml_string;
 }
 }
 //ini_set("soap.wsdl_cache_enabled", "0");
 $server = new SoapServer("catalog.wsdl");
 $server->addFunction("getCatalogEntry");
 $server->handle();
 ?>
 
 
 catalog.wsdl
 <?xml version ='1.0' encoding ='UTF-8' ?>
 <definitions name='Catalog'
 targetNamespace='http://example.org/catalog'
 xmlns:tns=' http://example.org/catalog '
 xmlns:soap='http://schemas.xmlsoap.org/wsdl/soap/'
 xmlns:xsd='http://www.w3.org/2001/XMLSchema'
 xmlns:soapenc='http://schemas.xmlsoap.org/soap/encoding/'
 xmlns:wsdl='http://schemas.xmlsoap.org/wsdl/'
 xmlns='http://schemas.xmlsoap.org/wsdl/'>
 
 <message name='getCatalogRequest'>
 <part name='catalogId' type='xsd:string'/>
 </message>
 <message name='getCatalogResponse'>
 <part name='Result' type='xsd:string'/>
 </message>
 
 <portType name='CatalogPortType'>
 <operation name='getCatalogEntry'>
 <input message='tns:getCatalogRequest'/>
 <output message='tns:getCatalogResponse'/>
 </operation>
 </portType>
 
 <binding name='CatalogBinding' type='tns:CatalogPortType'>
 <soap:binding style='rpc' transport='http://schemas.xmlsoap.org/soap/http'/>
 <operation name='getCatalogEntry'>
 <soap:operation soapAction='urn:localhost-catalog#getCatalogEntry'/>
 <input>
 <soap:body use='encoded' namespace='urn:localhost-catalog' encodingStyle='http://schemas.xmlsoap.org/soap/encoding/'/>
 </input>
 <output>
 <soap:body use='encoded' namespace='urn:localhost-catalog' encodingStyle='http://schemas.xmlsoap.org/soap/encoding/'/>
 </output>
 </operation>
 </binding>
 
 <service name='CatalogService'>
 <port name='CatalogPort' binding='CatalogBinding'>
 <soap:address location='http://localhost/soap-server.php'/>
 </port>
 </service>
 </definitions>
 |  | 
| Back to top |  | 
| James Blond Moderator
 
  
 Joined: 19 Jan 2006
 Posts: 7442
 Location: EU, Germany, Next to Hamburg
 
 | 
|  Posted: Tue 03 Aug '10 11:43    Post subject: |   |  
| 
 |  
| Script time out? Did you enable the error log for PHP? 
 e.g.
 php.ini
 
  	  | Code: |  	  | error_reporting = E_ALL | E_STRICT
 log_errors = On
 error_log = "C:\Apache22\logs\php_errors.log"
 
 | 
 |  | 
| Back to top |  | 
| SUNJIB 
 
 
 Joined: 08 Jul 2010
 Posts: 8
 
 
 | 
|  Posted: Wed 04 Aug '10 6:42    Post subject: SOAP WebService not ABLE to return RESULT for > 40 Record |   |  
| 
 |  
| Thanks for your reply, This is in my Error Log 
 04-Aug-2010 04:23:22] PHP Fatal error:  Uncaught SoapFault exception: [Client] looks like we got no XML document in C:\Program Files\Apache Software Foundation\Apache2.2\htdocs\soap-client1.php:31
 Stack trace:
 #0 [internal function]: SoapClient->__call('getCatalogEntry', Array)
 #1 C:\Program Files\Apache Software Foundation\Apache2.2\htdocs\soap-client1.php(31): SoapClient->getCatalogEntry('3')
 #2 {main}
 thrown in C:\Program Files\Apache Software Foundation\Apache2.2\htdocs\soap-client1.php on line 31
 |  | 
| Back to top |  | 
| James Blond Moderator
 
  
 Joined: 19 Jan 2006
 Posts: 7442
 Location: EU, Germany, Next to Hamburg
 
 | 
|  Posted: Wed 04 Aug '10 11:04    Post subject: |   |  
| 
 |  
| So there is an program error. 
  	  | Quote: |  	  | looks like we got no XML document
 
 | 
 
 Which url do you fetch? Is it the catalog.wsdl or a generated page from php?
 |  | 
| Back to top |  | 
| SUNJIB 
 
 
 Joined: 08 Jul 2010
 Posts: 8
 
 
 | 
|  Posted: Wed 04 Aug '10 17:32    Post subject: |   |  
| 
 |  
| Dear james: 
 I ping http://serverip/soap-client.php?catalogid=1.
 
 This works perfectly for Aprox 30 records, But what is the issue with more records.
 
 I have added code abhove you can refer.
 
 Please suggest.
 
 Thanks in Advance.
 Sunjib
 |  | 
| Back to top |  | 
| James Blond Moderator
 
  
 Joined: 19 Jan 2006
 Posts: 7442
 Location: EU, Germany, Next to Hamburg
 
 | 
|  Posted: Wed 04 Aug '10 20:32    Post subject: |   |  
| 
 |  
| As I guessed in my first post Script time out 
 I can use set_time_limit
 
 e.g.
 
  	  | Code: |  	  | set_time_limit(60);
 //now the script can run 60 seconds.
 
 | 
 
 Your script seems to be very slow. SELECT * is not a good behaviour. You should only select the fields you need. Do you use indexes in your mysql table?
 |  | 
| Back to top |  | 
| SUNJIB 
 
 
 Joined: 08 Jul 2010
 Posts: 8
 
 
 | 
|  Posted: Thu 05 Aug '10 8:32    Post subject: |   |  
| 
 |  
| Hi James, 
 Thanks for you Suggestion.
 
 I feel this is not a Timeout Issue, the reason is If I do not RETURN the XML
 and simply echo the XML, it works perfectly.
 
 URL For your Referance: This could bring me 400 products presently
 http://113.19.86.34/soapTest.php
 
 when I return the XML RESULT SET from the function "getCatalogEntry($catalogid)" in Soap-Server.php to Soap-client.php It through error.
 
 Can I have your email id, I can forward you the web service Files.
 
 Thanks and REgards
 SUNJIB
 sunjib@rediffmail.com
 
 
 CoDE for your reference:
 $table_id = 'Product';
 $query = "select id,CatlogNo,Description,Qty,price,CatId,moreurl from Product";
 $dbresult = mysql_query($query, $Conn);
 
 $doc = new DomDocument('1.0');
 $root = $doc->createElement('root');
 $root = $doc->appendChild($root);
 
 while($row = mysql_fetch_array($dbresult, MYSQL_ASSOC))
 {
 $occ = $doc->createElement($table_id);
 $occ = $root->appendChild($occ);
 foreach ($row as $fieldname => $fieldvalue)
 {
 $child = $doc->createElement($fieldname);
 $child = $occ->appendChild($child);
 
 $value = $doc->createTextNode($fieldvalue);
 $value = $child->appendChild($value);
 }
 }
 
 $xml_string = $doc->saveXML();
 echo $xml_string;
 |  | 
| Back to top |  | 
| SUNJIB 
 
 
 Joined: 08 Jul 2010
 Posts: 8
 
 
 | 
|  Posted: Fri 06 Aug '10 12:40    Post subject: how to Build XML with the characters like ™ ® |   |  
| 
 |  
| Dear James, 
 Can you help me how to Build XML with the characters like ™ ®
 
 Example:
 Alexa Fluor® Conjugated Antibodies
 HeLa QuikChIP™ Sheared Chromatin
 
 Thanks and Regards
 Sunjib
 |  | 
| Back to top |  | 
| James Blond Moderator
 
  
 Joined: 19 Jan 2006
 Posts: 7442
 Location: EU, Germany, Next to Hamburg
 
 |  | 
| Back to top |  | 
| SUNJIB 
 
 
 Joined: 08 Jul 2010
 Posts: 8
 
 
 | 
|  Posted: Mon 09 Aug '10 13:29    Post subject: |   |  
| 
 |  
| Dear James: 
 I could not read the article you sent me. Can you send me the solution in english only.
 
 
 Can you help me how to Build XML with the characters like ™ ®
 
 
 Regards
 SUNJIB
 |  | 
| Back to top |  | 
| James Blond Moderator
 
  
 Joined: 19 Jan 2006
 Posts: 7442
 Location: EU, Germany, Next to Hamburg
 
 |  | 
| Back to top |  |