Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b0df287d64 | ||
|
|
4221ee5138 | ||
|
|
ec5828c8aa | ||
|
|
0293eb258c | ||
|
|
a1ed45be55 |
30
README.md
30
README.md
@@ -159,6 +159,12 @@ $response = Unirest\Request::get("http://mockbin.com/request", null, null, "user
|
|||||||
|
|
||||||
### Cookies
|
### Cookies
|
||||||
|
|
||||||
|
Set a cookie string to specify the contents of a cookie header. Multiple cookies are separated with a semicolon followed by a space (e.g., "fruit=apple; colour=red")
|
||||||
|
|
||||||
|
```php
|
||||||
|
Unirest\Request::cookie($cookie)
|
||||||
|
```
|
||||||
|
|
||||||
Set a cookie file path for enabling cookie reading and storing cookies across multiple sequence of requests.
|
Set a cookie file path for enabling cookie reading and storing cookies across multiple sequence of requests.
|
||||||
|
|
||||||
```php
|
```php
|
||||||
@@ -269,7 +275,7 @@ Unirest\Request::defaultHeader("Header1", "Value1");
|
|||||||
Unirest\Request::defaultHeader("Header2", "Value2");
|
Unirest\Request::defaultHeader("Header2", "Value2");
|
||||||
```
|
```
|
||||||
|
|
||||||
You can do set default headers in bulk:
|
You can set default headers in bulk by passing an array:
|
||||||
|
|
||||||
```php
|
```php
|
||||||
Unirest\Request::defaultHeaders(array(
|
Unirest\Request::defaultHeaders(array(
|
||||||
@@ -284,6 +290,28 @@ You can clear the default headers anytime with:
|
|||||||
Unirest\Request::clearDefaultHeaders();
|
Unirest\Request::clearDefaultHeaders();
|
||||||
```
|
```
|
||||||
|
|
||||||
|
#### Default cURL Options
|
||||||
|
|
||||||
|
You can set default [cURL options](http://php.net/manual/en/function.curl-setopt.php) that will be sent on every request:
|
||||||
|
|
||||||
|
```php
|
||||||
|
Unirest\Request::curlOpt(CURLOPT_COOKIE, "foo=bar");
|
||||||
|
```
|
||||||
|
|
||||||
|
You can set options bulk by passing an array:
|
||||||
|
|
||||||
|
```php
|
||||||
|
Unirest\Request::curlOpts(array(
|
||||||
|
CURLOPT_COOKIE => "foo=bar"
|
||||||
|
));
|
||||||
|
```
|
||||||
|
|
||||||
|
You can clear the default options anytime with:
|
||||||
|
|
||||||
|
```php
|
||||||
|
Unirest\Request::clearCurlOpts();
|
||||||
|
```
|
||||||
|
|
||||||
#### SSL validation
|
#### SSL validation
|
||||||
|
|
||||||
You can explicitly enable or disable SSL certificate validation when consuming an SSL protected endpoint:
|
You can explicitly enable or disable SSL certificate validation when consuming an SSL protected endpoint:
|
||||||
|
|||||||
@@ -7,7 +7,9 @@ use Unirest\Response;
|
|||||||
|
|
||||||
class Request
|
class Request
|
||||||
{
|
{
|
||||||
|
private static $cookie = null;
|
||||||
private static $cookieFile = null;
|
private static $cookieFile = null;
|
||||||
|
private static $curlOpts = array();
|
||||||
private static $defaultHeaders = array();
|
private static $defaultHeaders = array();
|
||||||
private static $handle = null;
|
private static $handle = null;
|
||||||
private static $jsonOpts = array();
|
private static $jsonOpts = array();
|
||||||
@@ -71,11 +73,7 @@ class Request
|
|||||||
*/
|
*/
|
||||||
public static function defaultHeaders($headers)
|
public static function defaultHeaders($headers)
|
||||||
{
|
{
|
||||||
foreach ($headers as $name => $value) {
|
return array_merge(self::$defaultHeaders, $headers);
|
||||||
self::$defaultHeaders[$name] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $headers;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -89,6 +87,43 @@ class Request
|
|||||||
return self::$defaultHeaders[$name] = $value;
|
return self::$defaultHeaders[$name] = $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clear all the default headers
|
||||||
|
*/
|
||||||
|
public static function clearDefaultHeaders()
|
||||||
|
{
|
||||||
|
return self::$defaultHeaders = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set curl options to send on every request
|
||||||
|
*
|
||||||
|
* @param array $options options array
|
||||||
|
*/
|
||||||
|
public static function curlOpts($opts)
|
||||||
|
{
|
||||||
|
return array_merge(self::$curlOpts, $opts);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a new default header to send on every request
|
||||||
|
*
|
||||||
|
* @param string $name header name
|
||||||
|
* @param string $value header value
|
||||||
|
*/
|
||||||
|
public static function curlOpt($name, $value)
|
||||||
|
{
|
||||||
|
return self::$curlOpts[$name] = $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clear all the default headers
|
||||||
|
*/
|
||||||
|
public static function clearCurlOpts()
|
||||||
|
{
|
||||||
|
return self::$curlOpts = array();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a Mashape key to send on every request as a header
|
* Set a Mashape key to send on every request as a header
|
||||||
* Obtain your Mashape key by browsing one of your Mashape applications on https://www.mashape.com
|
* Obtain your Mashape key by browsing one of your Mashape applications on https://www.mashape.com
|
||||||
@@ -103,6 +138,16 @@ class Request
|
|||||||
return self::defaultHeader('X-Mashape-Key', $key);
|
return self::defaultHeader('X-Mashape-Key', $key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a coockie string for enabling coockie handling
|
||||||
|
*
|
||||||
|
* @param string $cookie
|
||||||
|
*/
|
||||||
|
public static function cookie($cookie)
|
||||||
|
{
|
||||||
|
self::$cookie = $cookie;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a coockie file path for enabling coockie handling
|
* Set a coockie file path for enabling coockie handling
|
||||||
*
|
*
|
||||||
@@ -115,14 +160,6 @@ class Request
|
|||||||
self::$cookieFile = $cookieFile;
|
self::$cookieFile = $cookieFile;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Clear all the default headers
|
|
||||||
*/
|
|
||||||
public static function clearDefaultHeaders()
|
|
||||||
{
|
|
||||||
return self::$defaultHeaders = array();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set authentication method to use
|
* Set authentication method to use
|
||||||
*
|
*
|
||||||
@@ -339,6 +376,9 @@ class Request
|
|||||||
{
|
{
|
||||||
self::$handle = curl_init();
|
self::$handle = curl_init();
|
||||||
|
|
||||||
|
// start with default options
|
||||||
|
curl_setopt_array(self::$handle, self::$curlOpts);
|
||||||
|
|
||||||
if ($method !== Method::GET) {
|
if ($method !== Method::GET) {
|
||||||
curl_setopt(self::$handle, CURLOPT_CUSTOMREQUEST, $method);
|
curl_setopt(self::$handle, CURLOPT_CUSTOMREQUEST, $method);
|
||||||
|
|
||||||
@@ -373,9 +413,13 @@ class Request
|
|||||||
curl_setopt(self::$handle, CURLOPT_TIMEOUT, self::$socketTimeout);
|
curl_setopt(self::$handle, CURLOPT_TIMEOUT, self::$socketTimeout);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (self::$cookie) {
|
||||||
|
curl_setopt(self::$handle, CURLOPT_COOKIE, self::$cookie);
|
||||||
|
}
|
||||||
|
|
||||||
if (self::$cookieFile) {
|
if (self::$cookieFile) {
|
||||||
curl_setopt($ch, CURLOPT_COOKIEFILE, self::$cookieFile);
|
curl_setopt(self::$handle, CURLOPT_COOKIEFILE, self::$cookieFile);
|
||||||
curl_setopt($ch, CURLOPT_COOKIEJAR, self::$cookieFile);
|
curl_setopt(self::$handle, CURLOPT_COOKIEJAR, self::$cookieFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
// supporting deprecated http auth method
|
// supporting deprecated http auth method
|
||||||
@@ -421,9 +465,15 @@ class Request
|
|||||||
return new Response($httpCode, $body, $header, self::$jsonOpts);
|
return new Response($httpCode, $body, $header, self::$jsonOpts);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getInfo()
|
public static function getInfo($opt = false)
|
||||||
{
|
{
|
||||||
return curl_getinfo(self::$handle);
|
if ($opt) {
|
||||||
|
$info = curl_getinfo(self::$handle, $opt);
|
||||||
|
} else {
|
||||||
|
$info = curl_getinfo(self::$handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $info;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getCurlHandle()
|
public static function getCurlHandle()
|
||||||
|
|||||||
@@ -16,6 +16,17 @@ class UnirestRequestTest extends \PHPUnit_Framework_TestCase
|
|||||||
$this->assertEquals($result['file'], $file);
|
$this->assertEquals($result['file'], $file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testCurlOpts()
|
||||||
|
{
|
||||||
|
Unirest\Request::curlOpt(CURLOPT_COOKIE, 'foo=bar');
|
||||||
|
|
||||||
|
$response = Unirest\Request::get('http://mockbin.com/request');
|
||||||
|
|
||||||
|
$this->assertTrue(property_exists($response->body->cookies, 'foo'));
|
||||||
|
|
||||||
|
Unirest\Request::clearCurlOpts();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @expectedException Exception
|
* @expectedException Exception
|
||||||
*/
|
*/
|
||||||
@@ -23,23 +34,11 @@ class UnirestRequestTest extends \PHPUnit_Framework_TestCase
|
|||||||
{
|
{
|
||||||
Unirest\Request::timeout(1);
|
Unirest\Request::timeout(1);
|
||||||
|
|
||||||
Unirest\Request::get('http://mockbin.com/delay/3000');
|
Unirest\Request::get('http://mockbin.com/delay/1000');
|
||||||
|
|
||||||
Unirest\Request::timeout(null); // Cleaning timeout for the other tests
|
Unirest\Request::timeout(null); // Cleaning timeout for the other tests
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
public function testTimeoutSuccess()
|
|
||||||
{
|
|
||||||
Unirest\Request::timeout(3);
|
|
||||||
|
|
||||||
$response = Unirest\Request::get('http://mockbin.com/delay/2000');
|
|
||||||
$this->assertEquals(200, $response->code);
|
|
||||||
|
|
||||||
Unirest\Request::timeout(null); // Cleaning timeout for the other tests
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
public function testDefaultHeader()
|
public function testDefaultHeader()
|
||||||
{
|
{
|
||||||
Unirest\Request::defaultHeader('Hello', 'custom');
|
Unirest\Request::defaultHeader('Hello', 'custom');
|
||||||
|
|||||||
Reference in New Issue
Block a user