Ich erhalte mein Inhaber-Token von einem API-Endpunkt und setze Folgendes fest:
$authorization = "Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274"
Als nächstes möchte ich CURL verwenden, um auf den sicheren Endpunkt zuzugreifen. Ich bin mir jedoch nicht sicher, wie oder wo ich das Bearer-Token setzen soll.
Ich habe es versucht, aber es funktioniert nicht:
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);
BEARBEITEN:
Der Dokumentation zufolge soll ich das Inhaber-Token als solches verwenden: https://apigility.org/documentation/auth/authentication-oauth2
GET /oauth/resource HTTP/1.1
Accept: application/json
Authorization: Bearer 907c762e069589c2cd2a229cdae7b8778caa9f07
Antworten:
Ersetzen:
$authorization = "Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274"
mit:
$authorization = "Authorization: Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274";
um es zu einem gültigen und funktionierenden Autorisierungsheader zu machen.
quelle
Dies ist eine cURL-Funktion, die Daten senden oder abrufen kann. Es sollte mit jeder PHP-App funktionieren, die OAuth unterstützt:
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 }
Verwenden Sie es für Einweg- oder Zweiweganfragen:
$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
quelle
Das sollte funktionieren
$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);
quelle
Beispiel für einen Verzehr:
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());
Siehe https://github.com/andriichuk/php-curl-cookbook#bearer-auth
quelle
Wie bei PHP 7.3:
quelle
Wenn Sie stattdessen mit einem privaten Token ( wie der Gitlab-API ) arbeiten, sollten Sie Folgendes ersetzen:
$authorization = "Authorization: Bearer 080042cad6356ad5dc0a720c18b53b8e53d4c274"
mit:
$authorization = "PRIVATE-TOKEN 080042cad6356ad5dc0a720c18b53b8e53d4c274";
quelle
<?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; ?>
quelle