Beim Schreiben von Hintergrundcode ist es unvermeidlich, mit anderen Schnittstellen von Drittanbietern zu interagieren, z. B. beim Senden von Vorlagennachrichten an Dienstkonten. Manchmal müssen möglicherweise mehr als 100.000 Nachrichten gesendet werden. Zu diesem Zeitpunkt müssen Sie die Verwendung asynchroner und „multithreadiger“ Netzwerkanforderungen in Betracht ziehen.
Heute empfehle ich PHP-Ingenieuren ein Guzzle-Plug-in.
Guzzle
Guzzle ist ein PHP-HTTP-Client, der zum einfachen Senden von Anfragen und zur Integration in unsere WEB-Dienste verwendet wird.
Einfache Schnittstelle: Erstellen Sie Abfrageanweisungen, POST-Anfragen, teilen Sie den Upload und Download großer Dateien auf, verwenden Sie HTTP-Cookies, laden Sie JSON-Daten hoch usw.
Senden Sie synchrone oder asynchrone Anfragen über dieselbe Schnittstelle.
Verwenden Sie die PSR-7-Schnittstelle zum Anfordern, Antworten und Auslagern, sodass Sie andere kompatible PSR-7-Klassenbibliotheken verwenden können, um gemeinsam mit Guzzle zu entwickeln.
Abstrahiert den zugrunde liegenden HTTP-Transport und ermöglicht es Ihnen, die Umgebung und anderen Code zu ändern, z. B. keine starke Abhängigkeit von cURL- und PHP-Streams oder -Sockets, nicht blockierende Ereignisschleife.
Mit Middleware-Systemen können Sie clientseitige Verhaltensweisen erstellen.
Guzzle installieren
In diesem Artikel wird das Laravel-Projekt kombiniert, um die grundlegende Verwendung von Guzzle vorzustellen. Daher ist die Verwendung von Composer zur Installation von Guzzle perfekt und wird auch auf der offiziellen Website von Guzzle empfohlen Mit Composer installieren.
composer require guzzlehttp/guzzle:~6.0 // 或者 php composer.phar require guzzlehttp/guzzle:~6.0
Senden Sie eine einfache POST-Anfrage
Greifen Sie auf Schnittstellen von Drittanbietern zu, bei denen es sich im Grunde um POST-Anfragen handelt. Wenn Sie ein einfaches intelligentes Chat-Tool erstellen möchten, können Sie die Turing Robot API verwenden, um eine POST-Anfrage zu senden, um den automatischen Antwortinhalt zu erhalten:
<?php namespace App\Http\Controllers; use GuzzleHttp\Client; use Illuminate\Http\Request; class GuzzleUseController extends Controller { public function tuling(Request $request) { $params = [ 'key' => '*****', 'userid' => 'yemeishu' ]; $params['info'] = $request->input('info', '你好吗'); $client = new Client(); $options = json_encode($params, JSON_UNESCAPED_UNICODE); $data = [ 'body' => $options, 'headers' => ['content-type' => 'application/json'] ]; // 发送 post 请求 $response = $client->post('http://www.tuling123.com/openapi/api', $data); $callback = json_decode($response->getBody()->getContents()); return $this->output_json('200', '测试图灵机器人返回结果', $callback); } }
Guzzle-Client->Post-Funktion ist immer noch sehr einfach. Ja, Sie müssen nur auf die Schnittstelle zugreifen und Parameter anfordern. Zu den Parametern gehören hauptsächlich: Text, Header, Abfrage usw. Weitere Informationen finden Sie unter
http://guzzle -cn.readthedocs.io/zh_CN /latest/quickstart.html#id8
Im Test:
Hinweis: Der Turing-Roboter ist immer noch sehr intelligent. Er kann den Kontext anhand derselben Benutzer-ID identifizieren und einen intelligenten Chat ermöglichen.
Senden Sie eine asynchrone POST-Anfrage
Bei der PHP-Entwicklung handelt es sich hauptsächlich um eine „prozessorientierte“ Entwicklungsmethode, bei der Anforderung jedoch um eine Schnittstelle eines Drittanbieters Manchmal muss nicht gewartet werden, bis die Schnittstelle des Drittanbieters Ergebnisse zurückgibt, bevor die Ausführung fortgesetzt wird. Wenn der Kauf des Benutzers beispielsweise erfolgreich ist, müssen wir eine Postanforderung an die SMS-Schnittstelle senden, und die SMS-Plattform sendet eine Textnachricht an den Benutzer, um ihn darüber zu informieren, dass die Zahlung erfolgreich war. Dies ist eine Art „Erinnerung“. Nachricht“ ist eine „zusätzliche Zusatzfunktion“ und wird nicht benötigt. „Wissen“, ob die Erinnerung erfolgreich versendet wurde, wenn der Benutzer bezahlt.
Zu diesem Zeitpunkt können Sie die asynchrone Anforderungsfunktion von Guzzle verwenden und sich den Code direkt ansehen:
public function sms(Request $request) { $code = $request->input('code'); $client = new Client(); $sid = '9815b4a2bb6d5******8bdb1828644f2'; $time = '20171029173312'; $token = 'af8728c8bc*******12019c680df4b11c'; $sig = strtoupper(md5($sid.$token.$time)); $auth = trim(base64_encode($sid . ":" . $time)); $params = ['templateSMS' => [ 'appId' => '12b43**********0091c73c0ab', 'param' => "coding01,$code,30", 'templateId' => '3***3', 'to' => '17689974321' ] ]; $options = json_encode($params, JSON_UNESCAPED_UNICODE); $data = [ 'query' => [ 'sig' => $sig ], 'body' => $options, 'headers' => [ 'content-type' => 'application/json', 'Authorization' => $auth ] ]; // 发送 post 请求 $promise = $client->requestAsync('POST', 'https://api.ucpaas.com/2014-06-30/Accounts/9815b4a2bb6d5******8bdb1828644f2/Messages/templateSMS', $data); $promise->then( function (ResponseInterface $res) { Log::info('---'); Log::info($res->getStatusCode() . "\n"); Log::info($res->getBody()->getContents() . "\n"); }, function (RequestException $e) { Log::info('-__-'); Log::info($e->getMessage() . "\n"); } ); $promise->wait(); return $this->output_json('200', '测试短信 api', []); }
Zuerst die Schnittstellendaten zurückgeben:
Dann geben Sie das Protokoll aus:
[2017-10-29 09:53:14] local.INFO: --- [2017-10-29 09:53:14] local.INFO: 200 [2017-10-29 09:53:14] local.INFO: {"resp":{"respCode":"000000","templateSMS":{"createDate":"20171029175314","smsId":"24a93f323c9*****8608568"}}}
Die letzte empfangene SMS-Nachricht:
Multithread-asynchrone POST-Anfrage senden
「Das Senden einer „Multithread-asynchronen POST-Anfrage“ wird in vielen Fällen verwendet. Zum Beispiel: Double Eleven ist bald verfügbar. Sie können einige Aktivitäten durchführen, um alten Benutzern etwas zurückzugeben Benutzer können den Benutzern mitteilen, an welchen Aktivitäten sie teilnehmen sollen. Zu diesem Zeitpunkt müssen Sie die offizielle WeChat-Kontoschnittstelle für asynchrone Multithread-Anfragen verwenden.
Gehen Sie direkt zum Code:
public function send($templateid, $openid, $url, $data) { $client = $this->bnotice->getHttp()->getClient(); $requests = function ($open_ids) use ($templateid, $url, $data) { foreach($open_ids as $v){ try { yield $this->bnotice ->template($templateid) ->to($v) ->url($url) ->data($data) ->request(); } catch(Exception $e) { Log::error('sendtemplate:'.$e->getMessage()); } } }; $pool = new Pool($client, $requests($openid), [ 'concurrency' => 16, 'fulfilled' => function ($response, $index) { }, 'rejected' => function ($reason, $index) { }, ]); $promise = $pool->promise(); $promise->wait(); }
Die Anforderungsmethode:
public function request($data = []) { $params = array_merge([ 'touser' => '', 'template_id' => '', 'url' => '', 'topcolor' => '', 'miniprogram' => [], 'data' => [], ], $data); $required = ['touser', 'template_id']; foreach ($params as $key => $value) { if (in_array($key, $required, true) && empty($value) && empty($this->message[$key])) { throw new InvalidArgumentException("Attribute '$key' can not be empty!"); } $params[$key] = empty($value) ? $this->message[$key] : $value; } $params['data'] = $this->formatData($params['data']); $this->message = $this->messageBackup; $options = json_encode ( $params, JSON_UNESCAPED_UNICODE); $data = [ 'query' => [ 'access_token' => $this->getAccessToken()->getToken() ], 'body' => $options, 'headers' => ['content-type' => 'application/json'] ]; return function() use ($data) { return $this->getHttp()->getClient()->requestAsync('POST', $this::API_SEND_NOTICE, $data); }; }
Verbrauchen Sie die asynchrone Multithread-Anforderungsprototypfunktion mit dem GuzzleHttpPool-Objekt
use GuzzleHttp\Pool;use GuzzleHttp\Client;use GuzzleHttp\Psr7\Request;$client = new Client();$requests = function ($total) { $uri = 'http://127.0.0.1:8126/guzzle-server/perf'; for ($i = 0; $i < $total; $i++) { yield new Request('GET', $uri); }};$pool = new Pool($client, $requests(100), [ 'concurrency' => 5, 'fulfilled' => function ($response, $index) { // this is delivered each successful response }, 'rejected' => function ($reason, $index) { // this is delivered each failed request },]);// Initiate the transfers and create a promise$promise = $pool->promise();// Force the pool of requests to complete.$promise->wait();
Zusammenfassung
Mit Guzzle ist es für uns sehr praktisch, Schnittstellen von Drittanbietern gleichzeitig und asynchron anzufordern. Wenn es die Zeit erlaubt, können wir einen Blick auf den Guzzle-Quellcode werfen, um zu sehen, wie er implementiert ist.
Empfohlenes Tutorial: „PHP-Tutorial“
Das obige ist der detaillierte Inhalt vonVerwendung des PHP-Netzwerkanforderungs-Plug-ins Guzzle. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!