當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ClientInterface::sendAll方法代碼示例

本文整理匯總了PHP中GuzzleHttp\ClientInterface::sendAll方法的典型用法代碼示例。如果您正苦於以下問題:PHP ClientInterface::sendAll方法的具體用法?PHP ClientInterface::sendAll怎麽用?PHP ClientInterface::sendAll使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在GuzzleHttp\ClientInterface的用法示例。


在下文中一共展示了ClientInterface::sendAll方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: runBatch

 public function runBatch()
 {
     $this->_guzzle->sendAll($this->_batch, ['error' => function (ErrorEvent $event) {
         $batchId = $event->getRequest()->getHeader('X-Batch-ID');
         $result = $this->_results[$batchId];
         if ($result instanceof ApiResult) {
             $result->readJson($event->getResponse()->getBody());
         }
     }, 'complete' => function (CompleteEvent $event) {
         $batchId = $event->getRequest()->getHeader('X-Batch-ID');
         $result = $this->_results[$batchId];
         if ($result instanceof ApiResult) {
             $result->readJson($event->getResponse()->getBody());
         }
     }]);
     $this->_batch = [];
     $this->_results = [];
 }
開發者ID:jdi,項目名稱:tntaffiliate,代碼行數:18,代碼來源:ApiClient.php

示例2: batch

 /**
  * Convenience method for sending multiple requests in parallel and
  * retrieving a hash map of requests to response objects or
  * RequestException objects.
  *
  * Note: This method keeps every request and response in memory, and as
  * such is NOT recommended when sending a large number or an indeterminable
  * number of requests in parallel.
  *
  * @param ClientInterface $client   Client used to send the requests
  * @param array|\Iterator $requests Requests to send in parallel
  * @param array           $options  Passes through the options available in
  *                                  {@see GuzzleHttp\ClientInterface::sendAll()}
  *
  * @return \SplObjectStorage Requests are the key and each value is a
  *     {@see GuzzleHttp\Message\ResponseInterface} if the request succeeded
  *     or a {@see GuzzleHttp\Exception\RequestException} if it failed.
  * @throws \InvalidArgumentException if the event format is incorrect.
  */
 function batch(ClientInterface $client, $requests, array $options = array())
 {
     $hash = new \SplObjectStorage();
     foreach ($requests as $request) {
         $hash->attach($request);
     }
     // Merge the necessary complete and error events to the event listeners
     // so that as each request succeeds or fails, it is added to the result
     // hash.
     $options = RequestEvents::convertEventArray($options, array('complete', 'error'), array('priority' => RequestEvents::EARLY, 'once' => true, 'fn' => function ($e) use($hash) {
         /** @noinspection PhpUndefinedMethodInspection */
         $hash[$e->getRequest()] = $e;
     }));
     // Send the requests in parallel and aggregate the results.
     $client->sendAll($requests, $options);
     // Update the received value for any of the intercepted requests.
     foreach ($hash as $request) {
         /** @var \GuzzleHttp\Event\ErrorEvent[] $hash */
         if ($hash[$request] instanceof CompleteEvent) {
             $hash[$request] = $hash[$request]->getResponse();
         } elseif ($hash[$request] instanceof ErrorEvent) {
             $hash[$request] = $hash[$request]->getException();
         }
     }
     return $hash;
 }
開發者ID:bobozhangshao,項目名稱:HeartCare,代碼行數:45,代碼來源:functions.php

示例3: batch

/**
 * Convenience method for sending multiple requests in parallel and retrieving
 * a hash map of requests to response objects or RequestException objects.
 *
 * Note: This method keeps every request and response in memory, and as such is
 * NOT recommended when sending a large number or an indeterminable number of
 * requests in parallel.
 *
 * @param ClientInterface $client   Client used to send the requests
 * @param array|\Iterator $requests Requests to send in parallel
 * @param array           $options  Passes through the options available in
 *                                  {@see GuzzleHttp\ClientInterface::sendAll()}
 * @return \SplObjectStorage Requests are the key and each value is a
 *     {@see GuzzleHttp\Message\ResponseInterface} if the request succeeded or
 *     a {@see GuzzleHttp\Exception\RequestException} if it failed.
 * @throws \InvalidArgumentException if the event format is incorrect.
 */
function batch(ClientInterface $client, $requests, array $options = [])
{
    $hash = new \SplObjectStorage();
    foreach ($requests as $request) {
        $hash->attach($request);
    }
    $handler = ['priority' => RequestEvents::EARLY, 'once' => true, 'fn' => function ($e) use($hash) {
        $hash[$e->getRequest()] = $e;
    }];
    // Merge the necessary complete and error events to the event listeners so
    // that as each request succeeds or fails, it is added to the result hash.
    foreach (['complete', 'error'] as $name) {
        if (!isset($options[$name])) {
            $options[$name] = $handler;
        } elseif (is_callable($options[$name])) {
            $options[$name] = [['fn' => $options[$name]], $handler];
        } elseif (is_array($options[$name])) {
            $options[$name][] = $handler;
        } else {
            throw new \InvalidArgumentException('Invalid event format');
        }
    }
    // Send the requests in parallel and aggregate the results.
    $client->sendAll($requests, $options);
    // Update the received value for any of the intercepted requests.
    foreach ($hash as $request) {
        if ($hash[$request] instanceof CompleteEvent) {
            $hash[$request] = $hash[$request]->getResponse();
        } elseif ($hash[$request] instanceof ErrorEvent) {
            $hash[$request] = $hash[$request]->getException();
        }
    }
    return $hash;
}
開發者ID:rasmusrosengren,項目名稱:CAS,代碼行數:51,代碼來源:functions.php


注:本文中的GuzzleHttp\ClientInterface::sendAll方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。