Obtengo mi token de portador de un punto final de API y configuro lo siguiente:
$authorization = "Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274"
A continuación, quiero usar CURL para acceder al punto final seguro, sin embargo, no estoy seguro de cómo o dónde configurar el token de portador.
He intentado esto pero no funciona:
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json' , $authorization ));
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POSTFIELDS,$post);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
$result = curl_exec($ch);
curl_close($ch);
return json_decode($result);
EDITAR:
De acuerdo con la documentación, se supone que debo usar el token de portador como tal: https://apigility.org/documentation/auth/authentication-oauth2
GET /oauth/resource HTTP/1.1
Accept: application/json
Authorization: Bearer 907c762e069589c2cd2a229cdae7b8778caa9f07
Respuestas:
Reemplazar:
$authorization = "Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274"
con:
$authorization = "Authorization: Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274";
para convertirlo en un encabezado de autorización válido y funcional.
fuente
Esta es una función cURL que puede enviar o recuperar datos. Debería funcionar con cualquier aplicación PHP que admita OAuth:
function jwt_request($token, $post) { header('Content-Type: application/json'); // Specify the type of data $ch = curl_init('https://APPURL.com/api/json.php'); // Initialise cURL $post = json_encode($post); // Encode the data array into a JSON string $authorization = "Authorization: Bearer ".$token; // Prepare the authorisation token curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json' , $authorization )); // Inject the token into the header curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_POST, 1); // Specify the request method as POST curl_setopt($ch, CURLOPT_POSTFIELDS, $post); // Set the posted fields curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); // This will follow any redirects $result = curl_exec($ch); // Execute the cURL statement curl_close($ch); // Close the cURL connection return json_decode($result); // Return the received data }
Úselo en solicitudes unidireccionales o bidireccionales:
$token = "080042cad6356ad5dc0a720c18b53b8e53d4c274"; // Get your token from a cookie or database $post = array('some_trigger'=>'...','some_values'=>'...'); // Array of data with a trigger $request = jwt_request($token,$post); // Send or retrieve data
fuente
Esto debería funcionar
$token = "YOUR_BEARER_AUTH_TOKEN"; //setup the request, you can also use CURLOPT_URL $ch = curl_init('API_URL'); // Returns the data/output as a string instead of raw data curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); //Set your auth headers curl_setopt($ch, CURLOPT_HTTPHEADER, array( 'Content-Type: application/json', 'Authorization: Bearer ' . $token )); // get stringified data/output. See CURLOPT_RETURNTRANSFER $data = curl_exec($ch); // get info about the request $info = curl_getinfo($ch); // close curl resource to free up system resources curl_close($ch);
fuente
Ejemplo de trago:
use GuzzleHttp\Client; use GuzzleHttp\RequestOptions; $token = 'your_token'; $httpClient = new Client(); $response = $httpClient->get( 'https://httpbin.org/bearer', [ RequestOptions::HEADERS => [ 'Accept' => 'application/json', 'Authorization' => 'Bearer ' . $token, ] ] ); print_r($response->getBody()->getContents());
Ver https://github.com/andriichuk/php-curl-cookbook#bearer-auth
fuente
Como en PHP 7.3:
fuente
Si está trabajando con un token privado en su lugar ( como la API de Gitlab ), debe reemplazar:
$authorization = "Authorization: Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274"
con:
$authorization = "PRIVATE-TOKEN 080042cad6356ad5dc0a720c18b53b8e53d4c274";
fuente
<?php $curl = curl_init(); curl_setopt_array($curl, array( CURLOPT_URL => "your api goes here", CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => "", CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => "GET", CURLOPT_HTTPHEADER => array( "Authorization: Bearer eyJ0eciOiJSUzI1NiJ9.eyJMiIsInNjb3BlcyI6W119.K3lW1STQhMdxfAxn00E4WWFA3uN3iIA" ), )); $response = curl_exec($curl); $data = json_decode($response, true); echo $data; ?>
fuente