Guzzle 使用教程

介绍

Guzzle是一个PHP的HTTP客户端,用来轻而易举地发送请求,并集成到我们的WEB服务上。

接口简单:构建查询语句、POST请求、分流上传下载大文件、使用HTTP cookies、上传JSON数据等等。
发送同步或异步的请求均使用相同的接口。
使用PSR-7接口来请求、响应、分流,允许你使用其他兼容的PSR-7类库与Guzzle共同开发。
抽象了底层的HTTP传输,允许你改变环境以及其他的代码,如:对cURL与PHP的流或socket并非重度依赖,非阻塞事件循环。
中间件系统允许你创建构成客户端行为。

了解http协议

HTTP是一个基于TCP/IP通信协议来传递数据,包括html文件、图像、结果等,即是一个客户端和服务器端请求和应答的标准。

HTTP协议特点
1.http无连接:限制每次连接只处理一个请求,服务端完成客户端的请求后,即断开连接。(传输速度快,减少不必要的连接,但也意味着每一次访问都要建立一次连接,效率降低)

2.http无状态:对于事务处理没有记忆能力。每一次请求都是独立的,不记录客户端任何行为。(优点解放服务器,但可能每次请求会传输大量重复的内容信息)

3.客户端/服务端模型:客户端支持web浏览器或其他任何客户端,服务器通常是apache或者iis等

4.简单快速

5.灵活:可以传输任何类型的数据

客户端请求消息

  • 请求行
  • 请求头部
  • 空行
  • 请求数据

黑白课堂

常见请求头

描述 (红色掌握,其他了解)

Referer

浏览器通知服务器,当前请求来自何处。如果是直接访问,则不会有这个头。常用于:防盗链

If-Modified-Since

浏览器通知服务器,本地缓存的最后变更时间。与另一个响应头组合控制浏览器页面的缓存。

Cookie

与会话有关技术,用于存放浏览器缓存的cookie信息。

User-Agent

浏览器通知服务器,客户端浏览器与操作系统相关信息

Connection

保持连接状态。Keep-Alive 连接中,close 已关闭

Host

请求的服务器主机名

Content-Length

请求体的长度

Content-Type

如果是POST请求,会有这个头,默认值为application/x-www-form-urlencoded,表示请求体内容使用url编码

Accept:

浏览器可支持的MIME类型。文件类型的一种描述方式。

MIME格式:大类型/小类型[;参数]

例如:

   text/html ,html文件

   text/css,css文件

   text/javascript,js文件

   image/*,所有图片文件

Accept-Encoding

浏览器通知服务器,浏览器支持的数据压缩格式。如:GZIP压缩

Accept-Language

浏览器通知服务器,浏览器支持的语言。各国语言(国际化i18n)

服务器响应消息

  • 状态行
  • 消息报头
  • 空行
  • 响应正文

黑白课堂
常用的状态码如下:

200 :请求成功。

302 :请求重定向。

304 :请求资源没有改变,访问本地缓存。

404 :请求资源不存在。通常是用户路径编写错误,也可能是服务器资源已删除。

500 :服务器内部错误。通常程序抛异常。

状态信息:状态信息是根据状态码变化而变化的

常见请求头

描述

Location

指定响应的路径,需要与状态码302配合使用,完成跳转。

Content-Type

响应正文的类型(MIME类型)

取值:text/html;charset=UTF-8

Content-Disposition

通过浏览器以下载方式解析正文

取值:attachment;filename=xx.zip

Set-Cookie

与会话相关技术。服务器向浏览器写入cookie

Content-Encoding

服务器使用的压缩格式

取值:gzip

Content-length

响应正文的长度

Refresh

定时刷新,格式:秒数;url=路径。url可省略,默认值为当前页。

取值:3;url=www.itcast.cn    //三秒刷新页面到www.itcast.cn

Server

指的是服务器名称,默认值:Apache-Coyote/1.1。可以通过conf/server.xml配置进行修改。<Connector port="8080" ... server="itcast"/>

Last-Modified

服务器通知浏览器,文件的最后修改时间。与If-Modified-Since一起使用。

版本要求

  • PHP 5.5.0
  • 使用PHP的流, allow_url_fopen 必须在php.ini中启用。
  • 要使用cURL,你必须已经有版本cURL >= 7.19.4,并且编译了OpenSSL 与 zlib。

安装

composer require guzzlehttp/guzzle:~6.0

快速入门

创建客户端

use GuzzleHttp\Client;

$client = new Client([
    // Base URI is used with relative requests
    'base_uri' => 'http://httpbin.org',
    // You can set any number of default request options.
    'timeout'  => 2.0,
]);

base_uri

$client = new GuzzleHttp\Client(['base_uri' => 'https://foo.com/api/']);
// Send a request to https://foo.com/api/test
$response = $client->request('GET', 'test');
// Send a request to https://foo.com/root
$response = $client->request('GET', '/root');

黑白课堂

发送请求

$response = $client->get('http://httpbin.org/get');
$response = $client->delete('http://httpbin.org/delete');
$response = $client->head('http://httpbin.org/get');
$response = $client->options('http://httpbin.org/get');
$response = $client->patch('http://httpbin.org/patch');
$response = $client->post('http://httpbin.org/post');
$response = $client->put('http://httpbin.org/put');

创建一个请求,一切就绪后将请求传送给client:

$request = new Request('PUT', 'http://httpbin.org/put');
$response = $client->send($request, ['timeout' => 2]);

异步请求

$promise = $client->getAsync('http://httpbin.org/get');
$promise = $client->deleteAsync('http://httpbin.org/delete');
$promise = $client->headAsync('http://httpbin.org/get');
$promise = $client->optionsAsync('http://httpbin.org/get');
$promise = $client->patchAsync('http://httpbin.org/patch');
$promise = $client->postAsync('http://httpbin.org/post');
$promise = $client->putAsync('http://httpbin.org/put');

实例利用cookie获取 登录后数据

这里以我黑白课堂网站作为实例讲解

1.第一步创建一个http客户端

前面要引入命名空间

use GuzzleHttp\Client;
use GuzzleHttp\Cookie\CookieJar;
$client = new Client([
            'verify'=>false,
            'base_uri' => 'https://www.heibaiketang.com', //设置这个网站的基本url地址,后续的只需要写相对路径即可
 ]);

2.设置cookies

这里获取很简单,直接在http请求头里面。
黑白课堂

$cookieJar = CookieJar::fromArray([
            'remember_forum_59ba36addc2b2f9401580f014XXXXXXXXX' => 'eyJpdiI6IlArUnJrdFMyQ3h6RlR3d2liQXVFU2c9PSIsInZhbHVlIjoiNUN5RmJMZ1wvaElSeTJ5MnVKUFdvM2lWSTBkMnh0ZG11Rm83VTFYTExON3hnN2JFS3MxV2ZxY01aSnQzZCtyeVR1aDQxZ0pQK1ZvS2FVN2V5Q1FoQzRUYldhbXRua21QTzFJS0VXOXk2SHRJdVdoTjdYZGhRUzJsU0MrdnRUUHJZY3J2cnpGQTBVXC9WOThKTkJuWHgxK3BZcVNkeW9CVDhoeUJUUXVybDVaSDQ9IiwibWFjIjoiODU5MzFlMjNhYWUwYWRlNDk5ZTgzOGMzYjM2MDMyOTQyYzhkNzZhMDFhOGE0ZWMzXXXXXXXXX',
            'laravel_session'=>'eyJpdiI6InZ5T3lyU2FXMEEwN2NNRFVhNVwvT0NnPT0iLCJ2YWx1ZSI6ImkrbUNvQUxGMUVqVTdYOTVHNFwvWHlWeXA4dFlTNHp4ZEk5eVRMSVFuM3V2Mjg2TTB0eXArVzcxdThVQnNoVHpvIiwibWFjIjoiZWNmMmJmMWEwODMwZTBhMDA4ODBlZWUwYzVkMWNjY2ViNmVlMTRlMTQzMmI0MzBjZWNiNzcwZWFmOWFhMTkXXXXXX'
        ], 'www.heibaiketang.com');  // 此处记得请求域名需要保持跟请求的url host一致,否则不会携带此cookie。

登录cookies,打印看看

 print_r($cookieJar->toArray());

Array
(
    [0] => Array
        (
            [Name] => remember_forum_59ba36addc2b2f9401580f014c7f58ea4e30989d
            [Value] => eyJpdiI6IlArUnJrdFMyQ3h6RlR3d2liQXVFU2c9PSIsInZhbHVlIjoiNUN5RmJMZ1wvaElSeTJ5MnVKUFdvM2lWSTBkMnh0ZG11Rm83VTFYTExON3hnN2JFS3MxV2ZxY01aSnQzZCtyeVR1aDQxZ0pQK1ZvS2FVN2V5Q1FoQzRUYldhbXRua21QTzFJS0VXOXk2SHRJdVdoTjdYZGhRUzJsU0MrdnRUUHJZY3J2cnpGQTBVXC9WOThKTkJuWHgxK3BZcVNkeW9CVDhoeUJUUXVybDVaSDQ9IiwibWFjIjoiODU5MzFlMjNhYWUwYWRlNDk5ZTgzOGMzYjM2MDMyOTQyYzhkNzZhMDFhOGE0ZWMzYzFjZTIzYjZjNGFlMTk4YiJ9
            [Domain] => www.heibaiketang.com
            [Path] => /
            [Max-Age] => 
            [Expires] => 
            [Secure] => 
            [Discard] => 1
            [HttpOnly] => 
        )

    [1] => Array
        (
            [Name] => laravel_session
            [Value] => eyJpdiI6InZ5T3lyU2FXMEEwN2NNRFVhNVwvT0NnPT0iLCJ2YWx1ZSI6ImkrbUNvQUxGMUVqVTdYOTVHNFwvWHlWeXA4dFlTNHp4ZEk5eVRMSVFuM3V2Mjg2TTB0eXArVzcxdThVQnNoVHpvIiwibWFjIjoiZWNmMmJmMWEwODMwZTBhMDA4ODBlZWUwYzVkMWNjY2ViNmVlMTRlMTQzMmI0MzBjZWNiNzcwZWFmOWFhMTk2OSJ9
            [Domain] => www.heibaiketang.com
            [Path] => /
            [Max-Age] => 
            [Expires] => 
            [Secure] => 
            [Discard] => 1
            [HttpOnly] => 
        )

)

自动转化我们得参数请求数据。

3.发起获取数据

  $result = $client->get('/user', [
            'cookies' => $cookieJar,
        ]);

        print_r($result->getBody()->getContents());

黑白课堂
这样就获取了我登录这个账号得得信息。

提示

评论区 (0)

没有记录
支持 markdown,图片截图粘贴拖拽都可以自动上传。
黑白课堂

黑白课堂

混元大罗金仙 站长创业者玉树凌风每天醒来0收入

查看更多

最新视频课程

Laravel 的 PhpSpreadsheet 包入门

wap2App 入门讲解,100%速成,全面为你讲解。

ace.js 打造一款属于你的 Web 编辑器,入门文档。

Laravel Permission 中文文档

解释 OAuth 2.0 认证 和使用场景说明

Laravel 之 horizon 队列管理界面系统

钻级赞助商