该页面提供了Guzzle的快速入门以及列子,如果你还没有安装Guzzle请前往 安装 页面。
发送请求
你可以使用Guzzle的 GuzzleHttp\ClientInterface
对象来发送请求。
创建客户端
1 | use GuzzleHttp\Client; |
Client对象可以接收一个包含参数的数组:base_uri
(string|UriInterface) 基URI用来合并到相关URI,可以是一个字符串或者UriInterface的实例,当提供了相关uri,将合并到基URI,遵循的规则请参考 RFC 3986, section 5.2 章节。
1 | // Create a client with a base URI |
不想阅读RFC 3986?这里有一些关于 base_uri
与其他URI处理器的快速例子:
handler
传输HTTP请求的(回调)函数。 该函数被调用的时候包含 Psr7\Http\Message\RequestInterface
以及参数数组,必须返回 GuzzleHttp\Promise\PromiseInterface
,成功时满足 Psr7\Http\Message\ResponseInterface
。 handler
是一个构造方法,不能在请求参数里被重写。...
(混合) 构造方法中传入的其他所有参数用来当作每次请求的默认参数。
发送请求
Client对象的方法可以很容易的发送请求:
1 | $response = $client->get('http://httpbin.org/get'); |
你可以创建一个请求,一切就绪后将请求传送给client:
1 | use GuzzleHttp\Psr7\Request; |
Client对象为传输请求提供了非常灵活的处理器方式,包括请求参数、每次请求使用的中间件以及传送多个相关请求的基URI。
你可以在 Handlers and Middleware 页面找到更多关于中间件的内容。
异步请求
你可以使用Client提供的方法来创建异步请求:
1 | $promise = $client->getAsync('http://httpbin.org/get'); |
你也可以使用Client的 sendAsync() and requestAsync() 方法:
1 | use GuzzleHttp\Psr7\Request; |
这些方法返回了Promise对象,该对象实现了由 Guzzle promises library 提供的 Promises/A+ spec,这意味着你可以使用then()
来调用返回值,成功使用Psr\Http\Message\ResponseInterface
处理器,否则抛出一个异常。
1 | use Psr\Http\Message\ResponseInterface; |
并发请求
你可以使用Promise和异步请求来同时发送多个请求:
1 | use GuzzleHttp\Client; |
当你想发送不确定数量的请求时,可以使用GuzzleHttp\Pool
对象:
1 | use GuzzleHttp\Client; |
或者使用一个闭包,一旦池调用闭包,它将返回一个promise
。
1 | $client = new Client(); |
使用响应
前面的例子里,我们取到了$response
变量,或者从Promise得到了响应,Response对象实现了一个PSR-7接口Psr\Http\Message\ResponseInterface
,包含了很多有用的信息。
你可以获取这个响应的状态码和和原因短语(reason phrase):
1 | $code = $response->getStatusCode(); // 200 |
你可以从响应获取头信息(header):
1 | // Check if a header exists. |
使用getBody
方法可以获取响应的主体部分(body),主体可以当成一个字符串或流对象使用
1 | $body = $response->getBody(); |
查询字符串参数
你可以有多种方式来提供请求的查询字符串 你可以在请求的URI中设置查询字符串:
1 | $response = $client->request('GET', 'http://httpbin.org?foo=bar'); |
你可以使用query
请求参数来声明查询字符串参数:
1 | $client->request('GET', 'http://httpbin.org', [ |
提供的数组参数将会使用PHP的http_build_query
:
最后,你可以提供一个字符串作为query
请求参数:
1 | $client->request('GET', 'http://httpbin.org', ['query' => 'foo=bar']); |
上传数据
Guzzle为上传数据提供了一些方法。
你可以发送一个包含数据流的请求,将body
请求参数设置成一个字符串、fopen
返回的资源、或者一个Psr\Http\Message\StreamInterface
的实例。
1 | // Provide the body as a string. |
上传JSON数据以及设置合适的头信息可以使用json
请求参数这个简单的方式:
1 | $r = $client->request('PUT', 'http://httpbin.org/put', [ |
POST/表单请求
除了使用body
参数来指定请求数据外,Guzzle为发送POST数据提供了有用的方法。
发送表单字段
发送application/x-www-form-urlencoded
POST请求需要你传入form_params
数组参数,数组内指定POST的字段。
1 | $response = $client->request('POST', 'http://httpbin.org/post', [ |
发送表单文件
你可以通过使用multipart
请求参数来发送表单(表单enctype属性需要设置multipart/form-data
)文件, 该参数接收一个包含多个关联数组的数组,每个关联数组包含一下键名:
- name: (必须,字符串) 映射到表单字段的名称。
- contents: (必须,混合) 提供一个字符串,可以是
fopen
返回的资源、或者一个Psr\Http\Message\StreamInterface
以从PSR-7流中传输内容。
1 | $response = $client->request('POST', 'http://httpbin.org/post', [ |
Cookies
Guzzle可以使用cookies
请求参数为你维护一个cookie会话,当发送一个请求时,cookies
选项必须设置成GuzzleHttp\Cookie\CookieJarInterface
的实例。
1 | // Use a specific cookie jar |
如果您想对所有请求使用共享的cookie jar
,则可以在客户端构造函数中将cookie设置为true。
1 | // Use a shared client cookie jar |
GuzzleHttp\Cookie\CookieJarInterface
存在不同的实现:
-
GuzzleHttp\Cookie\CookieJar
类将cookie存储为数组。 -
GuzzleHttp\Cookie\FileCookieJar
类使用JSON格式的文件保留非会话cookie。 GuzzleHttp\Cookie\SessionCookieJar
类在客户端会话中保留cookie。
您可以使用命名构造函数fromArray(array $cookies, $domain)
将cookie手动设置到cookie jar中。
1 | $jar = \GuzzleHttp\Cookie\CookieJar::fromArray( |
您可以使用返回GuzzleHttp\Cookie\SetCookie
实例的getCookieByName($name)
方法获取其名称的cookie。
1 | $cookie = $jar->getCookieByName('some_cookie'); |
借助toArray()方法,也可以将cookie提取到数组中。GuzzleHttp\Cookie\CookieJarInterface
接口扩展了Traversable
,因此可以在foreach循环中进行迭代。
重定向
树形视图
下面的树形视图描述了Guzzle异常如何相互依赖。
. \RuntimeException
└── TransferException (implements GuzzleException)
└── ConnectException (implements NetworkExceptionInterface)
└── RequestException
├── BadResponseException
│ ├── ServerException
│ └── ClientException
└── TooManyRedirectsException
如果你没有告诉Guzzle不要重定向,Guzzle会自动的进行重定向,你可以使用allow_redirects
请求参数来自定义重定向行为。
- 设置成
true
时将启用最大数量为5的重定向,这是默认设置。 - 设置成
false
来禁用重定向。 - 传入一个包含
max
键名的关联数组来声明最大重定向次数,提供可选的strict
键名来声明是否使用严格的RFC标准重定向 (表示使用POST请求重定向POST请求 vs 大部分浏览器使用GET请求重定向POST请求)。
1 | $response = $client->request('GET', 'http://github.com'); |
下面的列子表示重定向被禁止:
1 | $response = $client->request('GET', 'http://github.com', [ |
异常
请求传输过程中出现的错误Guzzle将会抛出异常。
- 在发送网络错误(连接超时、DNS错误等)时,将会抛出
GuzzleHttp\Exception\RequestException
异常。 该异常继承自GuzzleHttp\Exception\TransferException
,捕获这个异常可以在传输请求过程中抛出异常。
1 | use GuzzleHttp\Psr7; |
GuzzleHttp\Exception\ConnectException
异常发生在网络错误时, 该异常继承自GuzzleHttp\Exception\RequestException
。如果
http_errors
请求参数设置成true,在400级别的错误的时候将会抛出GuzzleHttp\Exception\ClientException
异常, 该异常继承自GuzzleHttp\Exception\BadResponseException``GuzzleHttp\Exception\BadResponseException
继承自GuzzleHttp\Exception\RequestException
。
1 | use GuzzleHttp\Psr7; |
- 如果
http_errors
请求参数设置成true,在500级别的错误的时候将会抛出GuzzleHttp\Exception\ServerException
异常。 该异常继承自GuzzleHttp\Exception\BadResponseException
。 GuzzleHttp\Exception\TooManyRedirectsException
异常发生在重定向次数过多时, 该异常继承自GuzzleHttp\Exception\RequestException
。
上述所有异常均继承自GuzzleHttp\Exception\TransferException
。
环境变量
Guzzle提供了一些可自定义的环境变量:GUZZLE_CURL_SELECT_TIMEOUT
当在curl处理器时使用curl_multi_select()
控制了 curl_multi_* 需要使用到的持续时间, 有些系统实现PHP的curl_multi_select()
存在问题,调用该函数时总是等待超时的最大值。HTTP_PROXY
定义了使用http协议发送请求时使用的代理。HTTPS_PROXY
定义了使用https协议发送请求时使用的代理。
相关ini设置
Guzzle配置客户端时可以利用PHP的ini配置。openssl.cafile
当发送到”https”协议的请求时需要用到指定磁盘上PEM格式的CA文件,参考:https://wiki.php.net/rfc/tls-peer-verification#phpini_defaults