У меня все мои вызовы SOAP успешно работают в PHP CORE (когда я запускаю их в WAMP). Но когда я пытаюсь просто добавить тот же код на Zend Server, по какой-то причине он говорит: «Сервер обнаружил внутреннюю ошибку». Не уверен что происходит! Вызов с использованием SoapClient()
вообще не работает ... Я использую локальный WSDL и локальный мыльный сервис, предоставляемый Alchemy. В любом случае, я пробовал то же самое с Zend_Soap_Client
, но все равно это не работает !! Вот дамп созданного Zend Soap Client:
object(Zend_Soap_Client)#37 (29) { ["_encoding":protected]=> string(5) "UTF-8" ["_classmap":protected]=> NULL ["_faultExceptions":protected]=> array(0) { } ["_soapVersion":protected]=> int(2) ["_uri":protected]=> NULL ["_location":protected]=> NULL ["_style":protected]=> NULL ["_use":protected]=> NULL ["_login":protected]=> NULL ["_password":protected]=> NULL ["_proxy_host":protected]=> NULL ["_proxy_port":protected]=> NULL ["_proxy_login":protected]=> NULL ["_proxy_password":protected]=> NULL ["_local_cert":protected]=> NULL ["_passphrase":protected]=> NULL ["_compression":protected]=> NULL ["_connection_timeout":protected]=> NULL ["_stream_context":protected]=> NULL ["_features":protected]=> NULL ["_cache_wsdl":protected]=> NULL ["_user_agent":protected]=> NULL ["_wsdl":protected]=> string(77) "C:\Program Files (x86)\Zend\Apache2\htdocs\C3Nexus\application\WSAlchemy.wsdl" ["_soapClient":protected]=> NULL ["_lastMethod":protected]=> string(0) "" ["_soapInputHeaders":protected]=> array(0) { } ["_permanentSoapInputHeaders":protected]=> array(0) { } ["_soapOutputHeaders":protected]=> array(0) { } ["location"]=> string(29) "http://localhost:3434/Alchemy"
Даже вызов типа getFunctions()
на клиенте выдает ошибку. Что я делаю неправильно?
Обнаружил эти ошибки в ZendEnabler.log
[3/15/2013 2:21:55 PM] Error: Read data error - unable to get read result. Code 109.
[3/15/2013 2:21:55 PM] Error: Request for C:/Program Files (x86)/Zend/Apache2/htdocs/SOME/public/index.php: Unable to get the response from PHP process
[3/15/2013 2:21:55 PM] Error: PHP process 9872 from the "application/x-httpd-php" pool has exited with status 255.
Запрос URL: http://localhost:8089/SOME/public/index.php/NewPatient/load-gsdd-data
Следовательно,
Контроллер: NewPatient
Действие: loadGssdData
Я пишу мыльный вызов в этом действии.
Это работает:
$hey = new Zend_Soap_Client(APPLICATION_PATH . '\WSAlchemy.wsdl');
$hey->location ='http://localhost:3434/Alchemy';
echo var_dump($hey);
Но терпит неудачу, когда я звоню $hey->getFunctions()
!
Это вообще не работает,
$hey = new SoapClient(APPLICATION_PATH . '\WSAlchemy.wsdl');
$hey->location ='http://localhost:3434/Alchemy';
echo var_dump($hey);
или даже это!
$hey = new SoapClient("http://localhost:8089/SOME/public/WSAlchemy.wsdl");
echo var_dump($hey);
Примечание. Я могу получить доступ к файлу wsdl по адресу http://localhost:8089/SOME/public/WSAlchemy.wsdl
Интересно, почему я не могу использовать SoapClient
в Zend Server, который является ядром PHP !! :(
Чтобы попробовать, я отключил Soap Client в Zend Server. Он сказал:
[15-Mar-2013 14:46:23] PHP Fatal error: Class 'SoapClient' not found in C:\Program Files (x86)\Zend\Apache2\htdocs\SOME\application\controllers\GSDD.php on line 2
Итак, я снова включил, там нет ошибки, но я все равно получаю ошибку! Это мой журнал доступа к серверу после включения расширения:
127.0.0.1 - - [15/Mar/2013:14:54:06 -0400] "POST /ZendServer/index.php/Log-Tail/Index HTTP/1.1" 200 9205
127.0.0.1 - - [15/Mar/2013:14:54:07 -0400] "POST /ZendServer/index.php?controller=systray&action=exec&do=ping HTTP/1.1" 200 643
127.0.0.1 - - [15/Mar/2013:14:54:35 -0400] "GET /SOME/public/index.php/NewPatient/load-gsdd-data HTTP/1.1" 500 499
Итак, когда я загружаюсь, я получаю следующее:
После того, как я открываю этот файл, там есть ошибка сервера.
Остальные контроллеры и действия работают нормально! У меня просто проблема с этим действием.
Большое спасибо за уделенное время :)
libxml
должен быть включен, и если вы используете SSL с этой службой, убедитесь, чтоopenssl
настроен. Попробуйте отключить кеширование WSDL и включить параметр трассировки (отладка) с помощью SoapClient. - person ficuscr   schedule 15.03.2013ini_set('soap.wsdl_cache_enabled',0); ini_set('soap.wsdl_cache_ttl',0);
, но все равно не повезло! Опция трассировки включена Zend по умолчанию. Спасибо за ответ :) - person Yash   schedule 15.03.2013error_reporting
уровень? Не просто подавить ошибки? Не могу отладить общую «Внутреннюю ошибку сервера». - person ficuscr   schedule 15.03.2013