Edit report at http://bugs.php.net/bug.php?id=50698&edit=1
ID: 50698 User updated by: zippy1981 at gmail dot com Reported by: zippy1981 at gmail dot com Summary: SoapClient should handle wsdls with some incompatiable endpoints Status: Open Type: Feature/Change Request -Package: Feature/Change Request +Package: *General Issues Operating System: Windows XP/7 and probably all. PHP Version: 5.2.12, 5.3.1 New Comment: Below is a patch that helps to fix the behavior. The following problems remain: 1) If the wsdl contains only non http endpoints, and the location parameter is not specified, a proper error message is not generated. 2) If the wsdl contains only non http endpoints, and the location parameter is specified, the error "Uncaught SoapFault exception: [Client] Function ("echo") is not a valid method for this service in File.php:21" is displayed. Index: ext/soap/php_sdl.c =================================================================== --- ext/soap/php_sdl.c (revision 297339) +++ ext/soap/php_sdl.c (working copy) @@ -832,7 +832,12 @@ if (strncmp((char*)tmp- >children->content, WSDL_HTTP_TRANSPORT, sizeof(WSDL_HTTP_TRANSPORT)) == 0) { soapBinding- >transport = SOAP_TRANSPORT_HTTP; } else { - soap_error1(E_ERROR, "Parsing WSDL: PHP-SOAP doesn't support transport '%s'", tmp->children->content); + // Since this is an E_NOTICE severity message, it will disappear into the ether. + soap_error1(E_NOTICE, "Parsing WSDL: PHP-SOAP doesn't support transport '%s'", tmp->children->content); + efree(soapBinding); + efree(tmpbinding); + trav = trav- >next; + continue; } } } Previous Comments: ------------------------------------------------------------------------ [2010-01-13 20:59:45] zippy1981 at gmail dot com Thanks for your reply. On my initial report I posted an example client. In a comment in the example client is a link to a github repo with a .NET web service that causes this issue (e.g. config file was bound to nettcp): http://github.com/zippy1981/EchoService Inside the .net service is also a copy of the PHP client. The .NET code can be compiled on any windows machine with the free IDE SharpDevelop (http://www.icsharpcode.net/OpenSource/SD/Download/) I can provide a manually generated wsdl with false endpoints if needed. I'll gladly help test a fix or provide a mock if needed. ------------------------------------------------------------------------ [2010-01-13 20:29:39] srina...@php.net thanks for the clarification. if you can provide a test case /script , it would help us to work on this. thanks again for taking time for following up on this. your help will definitely help PHP make better ! ------------------------------------------------------------------------ [2010-01-13 15:05:54] zippy1981 at gmail dot com It seems I was not clear in my original ticket. My soap service has two end points. One is http (soap 1.1). The other is nettcp, microsoft private protocol. PHP throws an error when I parse the WSDL simply because it contains an endpoint it can't connect to. This is in spite of the following four facts: 1) There is a http endpoint it knows how to connect to in the WSDL 2) I override the WSDL endpoints in the soap constructor. 3) A soap client only needs to connect to one endpoint in a WSDL to communicate with it If I manually edit the WSDL so that the nettcp endpoint is no longer advertised, but it still exists, PHP will connect to it fine. ------------------------------------------------------------------------ [2010-01-13 14:41:18] srina...@php.net as far as I understand, Microsoft TCP transport spec is a private interface for communicating between .Net server/clients. I would expect that you will need SOAP/TCP as end point for communicating between php client and .Net server. Af course,my knowledge might be outdated on this. ------------------------------------------------------------------------ [2010-01-12 21:49:27] zippy1981 at gmail dot com Verified on Windows 7 as well. ------------------------------------------------------------------------ The remainder of the comments for this report are too long. To view the rest of the comments, please view the bug report online at http://bugs.php.net/bug.php?id=50698 -- Edit this bug report at http://bugs.php.net/bug.php?id=50698&edit=1