HTTP Requests
Introduction
This page is about HTTP requests that are going from your application to some remote server.
To perform such HTTP request, this framework is using cURL so you need to have php8.1-curl
extension installed on your
system.
All PHP classes are within the \Koldy\Http
namespace, so in order for example to work on this page, you have to:
use Koldy\Http;
Quick Request
There are few methods prepared for you to make quick HTTP requests:
$response = Request::get('https://koldy.net');
$response
will be instance of \Koldy\Http\Response
which has all the information you need, like:
echo $response->getBody();
echo $response->getHttpCode(); // 200 if it's OK
echo $response->getTotalTimeMs(); // get total execution time in milliseconds
To set additional parameters and/or request headers to quick requests, simply append it as:
$params = ['page' => 2];
$headers = ['Content-Type', 'application/json'];
$response = Request::get('https://koldy.net', $params, $headers);
Beside Request::get()
, you can use Request::post()
, Request::put()
and Request::delete()
.
Constructing Request With More Options
To construct Request object with more options, simply initialize new instance:
$request = new Request();
$request->setUrl('https://koldy.net');
$request->setMethod(Request::POST);
$request->setParam('page', 2);
$request->setHeader('auth', md5('secret'));
$request->setOption(CURLOPT_FOLLOWLOCATION, true);
$request->setOption(CURLOPT_MAXREDIRS, 5);
Log::debug($request);
$response = $request->exec();
Log::debug($response);
In the example above, you can see how to define request with all optional settings. When using setOption()
method,
feel free to use any CURL_* PHP constant with corresponding
value.
Troubleshooting
When troubleshooting, you can call $request->debug()
or $response->debug()
or simply print these variables and you'll
get some useful information about the performed actions.