php网络请求库,PHP Curl Class可以轻松发送HTTP请求并与Web API集成

PHP Curl Class: HTTP requests made easy

68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f72656c656173652f7068702d6375726c2d636c6173732f7068702d6375726c2d636c6173732e73766768747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6963656e73652f7068702d6375726c2d636c6173732f7068702d6375726c2d636c6173732e73766768747470733a2f2f696d672e736869656c64732e696f2f7472617669732f7068702d6375726c2d636c6173732f7068702d6375726c2d636c6173732e73766768747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f7068702d6375726c2d636c6173732f7068702d6375726c2d636c6173732e737667

PHP Curl Class makes it easy to send HTTP requests and integrate with web APIs.

f3b8873684866e77f061d0b664fe7da2.gif

Installation

To install PHP Curl Class, simply:

$ composer require php-curl-class/php-curl-class

For latest commit version:

$ composer require php-curl-class/php-curl-class @dev

Requirements

PHP Curl Class works with PHP 5.3, 5.4, 5.5, 5.6, 7.0, 7.1, 7.2, and HHVM.

Quick Start and Examples

More examples are available under /examples.

require __DIR__ . '/vendor/autoload.php';

use \Curl\Curl;

$curl = new Curl();

$curl->get('https://www.example.com/');

if ($curl->error) {

echo 'Error: ' . $curl->errorCode . ': ' . $curl->errorMessage . "\n";

} else {

echo 'Response:' . "\n";

var_dump($curl->response);

}

// https://www.example.com/search?q=keyword

$curl = new Curl();

$curl->get('https://www.example.com/search', array(

'q' => 'keyword',

));

$curl = new Curl();

$curl->post('https://www.example.com/login/', array(

'username' => 'myusername',

'password' => 'mypassword',

));

$curl = new Curl();

$curl->setBasicAuthentication('username', 'password');

$curl->setUserAgent('MyUserAgent/0.0.1 (+https://www.example.com/bot.html)');

$curl->setReferrer('https://www.example.com/url?url=https%3A%2F%2Fwww.example.com%2F');

$curl->setHeader('X-Requested-With', 'XMLHttpRequest');

$curl->setCookie('key', 'value');

$curl->get('https://www.example.com/');

if ($curl->error) {

echo 'Error: ' . $curl->errorCode . ': ' . $curl->errorMessage . "\n";

} else {

echo 'Response:' . "\n";

var_dump($curl->response);

}

var_dump($curl->requestHeaders);

var_dump($curl->responseHeaders);

$curl = new Curl();

$curl->setOpt(CURLOPT_FOLLOWLOCATION, true);

$curl->get('https://shortn.example.com/bHbVsP');

$curl = new Curl();

$curl->put('https://api.example.com/user/', array(

'first_name' => 'Zach',

'last_name' => 'Borboa',

));

$curl = new Curl();

$curl->patch('https://api.example.com/profile/', array(

'image' => '@path/to/file.jpg',

));

$curl = new Curl();

$curl->patch('https://api.example.com/profile/', array(

'image' => new CURLFile('path/to/file.jpg'),

));

$curl = new Curl();

$curl->delete('https://api.example.com/user/', array(

'id' => '1234',

));

// Enable all supported encoding types and download a file.

$curl = new Curl();

$curl->setOpt(CURLOPT_ENCODING , '');

$curl->download('https://www.example.com/file.bin', '/tmp/myfile.bin');

// Case-insensitive access to headers.

$curl = new Curl();

$curl->download('https://www.example.com/image.png', '/tmp/myimage.png');

echo $curl->responseHeaders['Content-Type'] . "\n"; // image/png

echo $curl->responseHeaders['CoNTeNT-TyPE'] . "\n"; // image/png

// Clean up.

$curl->close();

// Example access to curl object.

curl_set_opt($curl->curl, CURLOPT_USERAGENT, 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1');

curl_close($curl->curl);

require __DIR__ . '/vendor/autoload.php';

use \Curl\MultiCurl;

// Requests in parallel with callback functions.

$multi_curl = new MultiCurl();

$multi_curl->success(function($instance) {

echo 'call to "' . $instance->url . '" was successful.' . "\n";

echo 'response:' . "\n";

var_dump($instance->response);

});

$multi_curl->error(function($instance) {

echo 'call to "' . $instance->url . '" was unsuccessful.' . "\n";

echo 'error code: ' . $instance->errorCode . "\n";

echo 'error message: ' . $instance->errorMessage . "\n";

});

$multi_curl->complete(function($instance) {

echo 'call completed' . "\n";

});

$multi_curl->addGet('https://www.google.com/search', array(

'q' => 'hello world',

));

$multi_curl->addGet('https://duckduckgo.com/', array(

'q' => 'hello world',

));

$multi_curl->addGet('https://www.bing.com/search', array(

'q' => 'hello world',

));

$multi_curl->start(); // Blocks until all items in the queue have been processed.

More examples are available under /examples.

Available Methods

Curl::__construct($base_url = null)

Curl::__destruct()

Curl::__get($name)

Curl::attemptRetry()

Curl::beforeSend($callback)

Curl::buildPostData($data)

Curl::call()

Curl::close()

Curl::complete($callback)

Curl::delete($url, $query_parameters = array(), $data = array())

Curl::download($url, $mixed_filename)

Curl::error($callback)

Curl::exec($ch = null)

Curl::execDone()

Curl::get($url, $data = array())

Curl::getAttempts()

Curl::getBeforeSendCallback()

Curl::getCompleteCallback()

Curl::getCookie($key)

Curl::getCurl()

Curl::getCurlErrorCode()

Curl::getCurlErrorMessage()

Curl::getDownloadCompleteCallback()

Curl::getErrorCallback()

Curl::getErrorCode()

Curl::getErrorMessage()

Curl::getFileHandle()

Curl::getHttpErrorMessage()

Curl::getHttpStatusCode()

Curl::getId()

Curl::getInfo($opt = null)

Curl::getJsonDecoder()

Curl::getOpt($option)

Curl::getRawResponse()

Curl::getRawResponseHeaders()

Curl::getRemainingRetries()

Curl::getRequestHeaders()

Curl::getResponse()

Curl::getResponseCookie($key)

Curl::getResponseCookies()

Curl::getResponseHeaders()

Curl::getRetries()

Curl::getRetryDecider()

Curl::getSuccessCallback()

Curl::getUrl()

Curl::getXmlDecoder()

Curl::head($url, $data = array())

Curl::isChildOfMultiCurl()

Curl::isCurlError()

Curl::isError()

Curl::isHttpError()

Curl::options($url, $data = array())

Curl::patch($url, $data = array())

Curl::post($url, $data = '', $follow_303_with_post = false)

Curl::progress($callback)

Curl::put($url, $data = array())

Curl::removeHeader($key)

Curl::reset()

Curl::search($url, $data = array())

Curl::setBasicAuthentication($username, $password = '')

Curl::setConnectTimeout($seconds)

Curl::setCookie($key, $value)

Curl::setCookieFile($cookie_file)

Curl::setCookieJar($cookie_jar)

Curl::setCookieString($string)

Curl::setCookies($cookies)

Curl::setDefaultDecoder($mixed = 'json')

Curl::setDefaultJsonDecoder()

Curl::setDefaultTimeout()

Curl::setDefaultUserAgent()

Curl::setDefaultXmlDecoder()

Curl::setDigestAuthentication($username, $password = '')

Curl::setHeader($key, $value)

Curl::setHeaders($headers)

Curl::setJsonDecoder($mixed)

Curl::setMaxFilesize($bytes)

Curl::setOpt($option, $value)

Curl::setOpts($options)

Curl::setPort($port)

Curl::setProxy($proxy, $port = null, $username = null, $password = null)

Curl::setProxyAuth($auth)

Curl::setProxyTunnel($tunnel = true)

Curl::setProxyType($type)

Curl::setReferer($referer)

Curl::setReferrer($referrer)

Curl::setRetry($mixed)

Curl::setTimeout($seconds)

Curl::setUrl($url, $mixed_data = '')

Curl::setUserAgent($user_agent)

Curl::setXmlDecoder($mixed)

Curl::success($callback)

Curl::unsetHeader($key)

Curl::unsetProxy()

Curl::verbose($on = true, $output = STDERR)

MultiCurl::__construct($base_url = null)

MultiCurl::__destruct()

MultiCurl::addCurl(Curl $curl)

MultiCurl::addDelete($url, $query_parameters = array(), $data = array())

MultiCurl::addDownload($url, $mixed_filename)

MultiCurl::addGet($url, $data = array())

MultiCurl::addHead($url, $data = array())

MultiCurl::addOptions($url, $data = array())

MultiCurl::addPatch($url, $data = array())

MultiCurl::addPost($url, $data = '', $follow_303_with_post = false)

MultiCurl::addPut($url, $data = array())

MultiCurl::addSearch($url, $data = array())

MultiCurl::beforeSend($callback)

MultiCurl::close()

MultiCurl::complete($callback)

MultiCurl::error($callback)

MultiCurl::getOpt($option)

MultiCurl::removeHeader($key)

MultiCurl::setBasicAuthentication($username, $password = '')

MultiCurl::setConcurrency($concurrency)

MultiCurl::setConnectTimeout($seconds)

MultiCurl::setCookie($key, $value)

MultiCurl::setCookieFile($cookie_file)

MultiCurl::setCookieJar($cookie_jar)

MultiCurl::setCookieString($string)

MultiCurl::setCookies($cookies)

MultiCurl::setDigestAuthentication($username, $password = '')

MultiCurl::setHeader($key, $value)

MultiCurl::setHeaders($headers)

MultiCurl::setJsonDecoder($mixed)

MultiCurl::setOpt($option, $value)

MultiCurl::setOpts($options)

MultiCurl::setPort($port)

MultiCurl::setReferer($referer)

MultiCurl::setReferrer($referrer)

MultiCurl::setRetry($mixed)

MultiCurl::setTimeout($seconds)

MultiCurl::setUrl($url)

MultiCurl::setUserAgent($user_agent)

MultiCurl::setXmlDecoder($mixed)

MultiCurl::start()

MultiCurl::success($callback)

MultiCurl::unsetHeader($key)

MultiCurl::verbose($on = true, $output = STDERR)

Security

See SECURITY for security considerations.

Troubleshooting

See TROUBLESHOOTING for troubleshooting.

Run Tests

To run tests:

$ git clone https://github.com/php-curl-class/php-curl-class.git

$ cd php-curl-class/

$ composer update

$ ./tests/run.sh

To test all PHP versions in containers:

$ git clone https://github.com/php-curl-class/php-curl-class.git

$ cd php-curl-class/

$ ./tests/test_all.sh

Contribute

Check for open issues or open a new issue to start a discussion around a bug or feature.

Fork the repository on GitHub to start making your changes.

Write one or more tests for the new feature or that expose the bug.

Make code changes to implement the feature or fix the bug.

Send a pull request to get your changes merged and published.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值