Подтвердить что ты не робот

Исключить исключение SoapFault: [HTTP] Ошибка Получение заголовков HTTP

Я пытаюсь создать соединение с мылом для веб-сервисов Magento, однако я получаю сообщение об ошибке при попытке создать экземпляр класса клиента soap. Я могу просматривать wsdl файл в firefox без проблем, и я могу посмотреть, как php делает запрос для wsdl в журналах apaches, но он все еще не работает. Nusoap может подключаться.

$proxy = new SoapClient('someaddress?wsdl');

Ошибка

<b>Fatal error</b>:  Uncaught SoapFault exception: [HTTP] Error Fetching http headers in /home/sites/xxx/xxx_main/system/application/views/contentpage_templates/gift_service.php:29
Stack trace:
[internal function]: SoapClient-&gt;__doRequest('&lt;?xml version=&quot;...',    'http://cornishw...', 'urn:Mage_Api_Mo...', 1, 0)
[internal function]: SoapClient-&gt;__call('call', Array)
/home/sites/xxx/xxx_main/system/application/views/contentpage_templates/gift_service.php(29): SoapClient-&gt;call(NULL, 'catalog_categor...', 5, 'giftshop')
/home/sites/xxx/xxx_main/system/application/libraries/MY_Loader.php(586): include('/home/sites/cor...')
/home/sites/xxx/xxx_main/system/application/libraries/MY_Loader.php(228): MY_Loader-&gt;_ci_load(Array, '')
/home/sites/xxx/xxx_main/system/application/modules/contentpage/controllers/contentpage.php(44): MY_Loader-&gt;view('contentpage_tem...', false, true)
[internal function]: Contentpage-&gt;index()
/home/sites/xxx in <b>/home/sites/xxx/xxx_main/system/application/views/contentpage_templates/gift_service.php</b> on line <b>29</b>

Спасибо

4b9b3361

Ответ 1

Попробуйте установить:

default_socket_timeout = 120

в вашем файле php.ini.

Ответ 2

Вы пытались добавить

'trace'=>1,

для параметров создания SoapClient, а затем:

var_dump($client->__getLastRequest());
var_dump($client->__getLastResponse());

чтобы узнать, что происходит?

Ответ 3

Эта ошибка может появиться на клиенте, если на сервере возникла проблема. Например, если SOAP-сервер является PHP script с ошибкой синтаксического анализа, клиент будет терпеть неудачу с этим сообщением.

Если вы контролируете сервер, запустите свой Apache error_log на машине, на которой размещен SOAP-сервер. В CentOS вы найдете это в /var/log/httpd/error _log, поэтому команда:

tail -f/var/log/httpd/error_log

Теперь обновите клиент и посмотрите сообщение об ошибке. Будут показаны любые ошибки PHP с сервером script.

Надеюсь, что это поможет кому-то.

Ответ 4

Я столкнулся с той же проблемой.

Я запускал его как CLI. Так что PHP всегда работал, и ему приходилось делать мыльный звонок снова и снова через некоторое время.
Ошибка, которую я сделал, это использовать одноэлементный шаблон для этого. Я думал, что использование синглтона вызовет повышение производительности, но я хочу, чтобы я получил

Error Fetching http headers in ...

Я исправил его, создав новый saop-объект для каждого вызова.

Ответ 6

Если это проблема, связанная с Magento, вы должны отключить автоматическое повторное индексирование, поскольку это может привести к таймауту сокета (или истечению срока его действия). Вы можете вернуть его обратно, как только script завершит выполнение своих задач. Увеличение времени ожидания по умолчанию в php.ini также является хорошей идеей.

Ответ 7

В моем журнале ошибок apache я увидел:

[Tue Feb 16 14:55:02 2010] [notice] child pid 9985 exit signal File size limit exceeded (25)

Итак, я удалил все содержимое самого большого файла журнала 2.1GB/var/log/system.log. Теперь все работает.

Ответ 8

В версии php существует проблема с версией менее 5.2.6. Возможно, вам потребуется обновить версию php.

Ответ 9

Обновите свой php.ini с помощью

default_socket_timeout = 120

Вы можете создать свой собственный php.ini, если php установлен CGI вместо модуля Apache