JWT(JSON Web Token) (Seventh Token) Creation with CURL and Expire Time in CodeIgniter 3
<?php
defined("BASEPATH") or exit("No direct script access allowed");
use Firebase\JWT\JWT;
use Firebase\JWT\Key;
class RequestSeven extends CI_Controller
{
public function __construct()
{
parent::__construct();
}
public function index()
{
$key = "Seventh_Key";
//Set the expiration time to 1 hour from the current time
$issuedAt = time();
$expirationTime = $issuedAt + 3600; //jwt valid for 1 hour from the issued time
$payload = [
"id" => 39,
"name" => "Patel Sujal Pritambhai",
"age" => 30,
"gender" => "Male",
"email" => "patelsujal733@gmail.com",
"address" => "Odhav, Ahmedabad",
"position" => "Software developer",
"nationality" => "Indian",
"son name" => "Hardik",
"roll no" => 42,
"standard" => 11,
"Teacher name" => "Ajaybhai patel",
"school name" => "Devashya International School",
"school address" => "Nikol, Ahmedabad",
"city" => "Ahmedabad",
"pincode" => 362910,
"iat" => $issuedAt, //Issued at: time when the token was generated
"nbf" => $issuedAt, //Not before
"exp" => $expirationTime //Expiration time
];
$jwt = JWT::encode($payload, $key, "HS256");
$curl = curl_init();
curl_setopt_array($curl, [
CURLOPT_URL => 'http://localhost/blogApi/ApiSeven/users',
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => '',
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_SSL_VERIFYHOST => false,
CURLOPT_SSL_VERIFYPEER => false,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => 'GET',
CURLOPT_HTTPHEADER => [
'Accept: application/json',
'Authorization: Bearer ' . $jwt,
],
]);
$response = curl_exec($curl);
curl_close($curl);
print_r($response);
}
}
DECODE Data File
<?php
defined("BASEPATH") or exit("No direct script access allowed");
use chriskacerguis\RestServer\RestController;
use Firebase\JWT\JWT;
use Firebase\JWT\Key;
class ApiSeven extends RestController
{
public function __construct()
{
parent::__construct();
}
public function users_get()
{
$headers = apache_request_headers();
$jwt = $headers["Authorization"];
$jwt = str_replace("Bearer", "", $jwt);
$jwt = trim($jwt);
print_r($jwt);
echo "<br><br><br>";
try {
$decoded = JWT::decode($jwt, new Key("Seventh_Key", "HS256"));
echo json_encode(array(
"status" => "success",
"data" => $decoded
));
echo "<br><br><br>";
echo "<pre>";
$this->response($decoded);
} catch (\Firebase\JWT\ExpiredException $e) {
echo json_encode(array(
"status" => "error",
"message" => "Token is Expired"
));
} catch (Exception $e) {
echo json_encode(array(
"status" => "error",
"message" => $e->getMessage()
));
print_r($e->getMessage());
exit();
}
}
}
Comments
Post a Comment