當前位置: 首頁>>代碼示例>>PHP>>正文


PHP JWT::leeway方法代碼示例

本文整理匯總了PHP中Firebase\JWT\JWT::leeway方法的典型用法代碼示例。如果您正苦於以下問題:PHP JWT::leeway方法的具體用法?PHP JWT::leeway怎麽用?PHP JWT::leeway使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Firebase\JWT\JWT的用法示例。


在下文中一共展示了JWT::leeway方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: ValidateToken

 function ValidateToken()
 {
     try {
         $headers = getallheaders();
         if (!isset($headers['Authorization'])) {
             return;
         }
         $tokenObject = explode(' ', $headers['Authorization']);
         if (count($tokenObject) != 2) {
             return;
         }
         $tokenValue = $tokenObject[1];
         if ($tokenValue == NULL || $tokenValue == '') {
             return;
         }
         JWT::$leeway = 60 * 60 * 24;
         //24 hours
         $decoded = JWT::decode($tokenValue, "JWT_KEY", array('HS256'));
         if (empty($decoded)) {
             return;
         }
         $decoded_array = (array) $decoded;
         if (empty($decoded_array)) {
             return;
         }
         self::$token = $tokenValue;
         self::$userId = $decoded_array['uid'];
         self::$isAuthorized = TRUE;
     } catch (UnexpectedValueException $e) {
         return;
     } catch (Exception $e) {
         return;
     }
 }
開發者ID:vitalsaude,項目名稱:api,代碼行數:34,代碼來源:JWT_Controller.php

示例2: getJwt

 public function getJwt()
 {
     $return = [];
     $key = "352352345623463246trswrgsdfgsdfgsdfgsert";
     $token = array("iss" => "http://example.org", "aud" => "http://example.com", "iat" => time(), "nbf" => time() - 4123123);
     /**
      * IMPORTANT:
      * You must specify supported algorithms for your application. See
      * https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40
      * for a list of spec-compliant algorithms.
      */
     $jwt = JWT::encode($token, $key);
     $return[] = $jwt;
     $decoded = JWT::decode($jwt, $key, array('HS256'));
     $return[] = $decoded;
     /*
      NOTE: This will now be an object instead of an associative array. To get
      an associative array, you will need to cast it as such:
     */
     $decoded_array = (array) $decoded;
     $return[] = $decoded_array;
     /**
      * You can add a leeway to account for when there is a clock skew times between
      * the signing and verifying servers. It is recommended that this leeway should
      * not be bigger than a few minutes.
      *
      * Source: http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html#nbfDef
      */
     JWT::$leeway = 60;
     // $leeway in seconds
     $decoded = JWT::decode($jwt, $key, array('HS256'));
     $return[] = $decoded;
     return $return;
 }
開發者ID:vihoangson,項目名稱:Family,代碼行數:34,代碼來源:JwtLib.php

示例3: verifyToken

 public function verifyToken()
 {
     $token = null;
     $headers = apache_request_headers();
     /*
      * Look for the 'authorization' header
      */
     $authHeader = $headers['authorization'];
     if ($this->debug) {
         $this->utils->debug(__METHOD__, $authHeader);
     }
     if ($authHeader) {
         //$matches = array();
         //preg_match('/Token token="(.*)"/', $headers['Authorization'], $matches);
         //if(isset($matches[1])){
         //  $token = $matches[1];
         //}
         /*
          * Extract the jwt from the Bearer
          */
         //$jwt = sscanf($authHeader, 'Authorization: Bearer %s');
         $jwt = str_replace('Bearer ', '', $authHeader);
         if ($jwt) {
             /*
              * decode the jwt using the key from config
              */
             $privateKey = $this->utils->readFile('private/apikey');
             $secretKey = base64_decode($privateKey);
             JWT::$leeway = 5;
             $token = JWT::decode($jwt, $secretKey, array('HS512'));
             return $token;
         } else {
             /*
              * No token was able to be extracted from the authorization header
              */
             //header('HTTP/1.0 400 Bad Request');
             throw new Exception('Token was not able to be extracted from the authorization header');
             return false;
         }
     } else {
         /*
          * The request lacks the authorization token
          */
         //header('HTTP/1.0 400 Bad Request');
         throw new Exception('Token not found in request');
         return false;
     }
 }
開發者ID:bandjam,項目名稱:site-base,代碼行數:48,代碼來源:AuthController.php

示例4: isTokenValid

/**
* @name isTokenValid
* @description
* Helps in decoding the Token. If it's valid, returns the decoded_array. Otherwise, returns null
*/
function isTokenValid($tokenFromClient)
{
    try {
        // decode the jwt
        $secretKey = base64_decode(SECRET_KEY);
        JWT::$leeway = 60;
        // decode the key
        $token = JWT::decode($tokenFromClient, $secretKey, array('HS256'));
        // if no exception twron here, we are good to go.
        // let's also decode so we can access some info about the user.
        $decoded_array = (array) $token;
        // return
        return $decoded_array;
    } catch (Exception $e) {
        return NULL;
    }
}
開發者ID:healthy380,項目名稱:Angular-php-login-demo,代碼行數:22,代碼來源:index.php

示例5: tokenVerify

 /**
  * Decodes the JSON Web Token received as a request header.
  *
  * @param string $authHeader Bearer <token string>
  * @return array The decoded payload of the JWT
  */
 public static function tokenVerify($authHeader)
 {
     $tokenDecoded_array = [];
     if ($authHeader) {
         $jwt = substr($authHeader, 7);
         if ($jwt) {
             try {
                 JWT::$leeway = 60;
                 $tokenDecoded = JWT::decode($jwt, $GLOBALS['key'], array('HS256'));
                 $tokenDecoded_array = (array) $tokenDecoded;
             } catch (\Exception $e) {
                 echo "Unauthorized! " . $e->getMessage();
             }
         }
     } else {
         echo json_encode(array('status' => 'Bad request', 'message' => "No token from Authorization header!"));
     }
     return $tokenDecoded_array;
 }
開發者ID:andela-sachungo,項目名稱:php-checkpoints,代碼行數:25,代碼來源:Reusable.php

示例6: beforeFilter

 public function beforeFilter()
 {
     parent::beforeFilter();
     $this->layout = 'ajax';
     JWT::$leeway = 5;
     // $leeway in seconds
     try {
         $token = JWT::decode($this->request->header('Server-Token'), Configure::read('Autobahn.key'), array('HS256'));
     } catch (Exception $e) {
         throw new ForbiddenException('Could not auth your request');
     }
     $this->loadModel('User');
     if (!isset($token->userId) || !$this->User->exists($token->userId)) {
         throw new ForbiddenException('Could not auth your request or user does not exists');
     }
     $this->currUserID = $token->userId;
     $this->currUser = $this->User->findById($token->userId);
     $this->Auth->login($this->currUser['User']);
     if ($this->Auth->loggedIn()) {
         $this->_initTimezone($this->currUser['User']['timezone']);
         $this->_initLang($this->currUser['User']['lang']);
         $this->Auth->allow('*');
     }
 }
開發者ID:nilBora,項目名稱:konstruktor,代碼行數:24,代碼來源:MyTimeAppController.php

示例7: __construct

 /**
  * @param int $leeway for checking timestamps
  */
 public function __construct($leeway = null)
 {
     $leeway = $leeway ?: getenv('JWT_LEEWAY');
     JWT::$leeway = $leeway ?: 0;
 }
開發者ID:generationtux,項目名稱:jwt-artisan,代碼行數:8,代碼來源:FirebaseDriver.php

示例8: __construct

 /**
  * Constructor
  * @param string $secretKey injected kernel secret key
  */
 public function __construct($secretKey)
 {
     $this->jwtKey = self::PREPEND_KEY . $secretKey;
     JWT::$leeway = 5;
 }
開發者ID:stopfstedt,項目名稱:ilios,代碼行數:9,代碼來源:JsonWebTokenManager.php

示例9: __construct

 /**
  * JwtService constructor
  *
  * @param ClaimManagerContract $claimManager
  */
 public function __construct(ClaimManagerContract $claimManager)
 {
     $this->key = Config::get('jwt.secret');
     $this->claimManager = $claimManager;
     JWT::$leeway = Config::get('jwt.leeway');
 }
開發者ID:wisoot,項目名稱:jwt-guard,代碼行數:11,代碼來源:JwtService.php

示例10: show

 public function show()
 {
     $Model = new Model();
     $authority = M('authority');
     //  $USER->where('ID=201522040840')->select();
     $list = $authority->select();
     // echo M("authority")->getLastSql();
     //   $this->assign('list',$list);
     // $list=array('total'=>100,'row'=>$list);
     $token = json_encode($list);
     //json
     print_r($token);
     // $arr=json_decode($jlist);
     // echo '使用輸出'.$arr->row[0]->id;
     //    print_r($list[0]);
     //$arr[0]=$list[0];
     //  echo $list[0]['id'];
     /*  echo 'daole';
         $id=201522040840;
         $sql="select name from __PREFIX__user where id=$id";
         $res=mysql_query($sql);
         $res=$Model->query($sql);
         $Model = new Model()  */
     // 實例化一個model對象 沒有對應任何數據表
     //$Model->query("select * from __PREFIX__user where status=1");
     // 3.2.2版本以上還可以直接使用
     // $Model->query("select * from __USER__ where status=1");
     //json數組
     /*  $token = array(
          "iss" => "http://example.org",
          "aud" => "http://example.com",
          "iat" => 1356999524,
          "nbf" => 1357000000
         ); */
     /**
      * IMPORTANT:
      * You must specify supported algorithms for your application. See
      * https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40
      * for a list of spec-compliant algorithms.
      */
     $key = "example_key";
     $jwt = JWT::encode($token, $key);
     print_r($jwt);
     echo '<br>';
     $decoded = JWT::decode($jwt, $key, array('HS256'));
     //json
     print_r($decoded);
     $arr = json_decode($decoded);
     //php數組
     print_r($decoded->iss);
     echo '<br>';
     echo $arr->iss;
     echo '<br>';
     /*
     NOTE: This will now be an object instead of an associative array. To get
     an associative array, you will need to cast it as such:
     */
     $decoded_array = (array) $decoded;
     /**
      * You can add a leeway to account for when there is a clock skew times between
      * the signing and verifying servers. It is recommended that this leeway should
      * not be bigger than a few minutes.
      *
      * Source: http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html#nbfDef
      */
     JWT::$leeway = 60;
     // $leeway in seconds
     $decoded = JWT::decode($jwt, $key, array('HS256'));
     // $decoded[0]->id;
     /*   $Model=new Model();
           echo 'daole';
           $id=201522040840;
           $sql="select name from __PREFIX__user where id=$id";
           // $res=mysql_query($sql);
          $res=$Model->query($sql); */
     /*  $Model = new Model() // 實例化一個model對象 沒有對應任何數據表
          //$Model->query("select * from __PREFIX__user where status=1");
          // 3.2.2版本以上還可以直接使用
          $Model->query("select * from __USER__ where status=1");
         */
     print_r($res);
     /*        $authority = M('authority');
                //  $USER->where('ID=201522040840')->select();
                $list = $authority->select();
                // echo M("authority")->getLastSql();
                //   $this->assign('list',$list);
                // $list=array('total'=>100,'row'=>$list);
                $jlist=json_encode($list);
                // $arr=json_decode($jlist);
                // echo '使用輸出'.$arr->row[0]->id;
                //    print_r($list[0]);
                //$arr[0]=$list[0];
                //  echo $list[0]['id'];
                for($i=0;$i<=2;$i++){
                //  echo '='.$list[$i]['id'].';name='.$list[$i]['name'].'<br>';
                $arr[$i]=array(
                '學號'=>$list[$i]['id'],
                '姓名'=>$list[$i]['id']);
                }
               print_r( json_encode($arr)); */
//.........這裏部分代碼省略.........
開發者ID:ivyhappy,項目名稱:PHYMAN,代碼行數:101,代碼來源:TestfunctionController.class.php

示例11: init

 public function init()
 {
     parent::init();
     JWT::$leeway = $this->leeway;
     self::$_instance = $this;
 }
開發者ID:fproject,項目名稱:yii2-authclient,代碼行數:6,代碼來源:OAuth2.php

示例12: getMatchers

 public function getMatchers()
 {
     return ['beValidJWSToken' => function ($token) {
         /*
          * Ensure the token is:
          *  - a string
          *  - that can be decoded as a JWT,
          *  - validates against the API key
          *  - and contains the expected claims.
          */
         // Token must be a string.
         if (!is_string($token)) {
             throw new FailureException(sprintf('Token must be a string. ' . gettype($token) . ' found.'));
         }
         //---
         try {
             JWT::$leeway = 5;
             // $leeway in seconds
             $decoded = JWT::decode($token, self::API_KEY, array('HS256'));
         } catch (SignatureInvalidException $e) {
             throw new FailureException($e->getMessage());
         }
         //---
         // iss must match our service id.
         if ($decoded->iss !== self::SERVICE_ID) {
             throw new FailureException(sprintf(sprintf("Unable to validate iss claim. '%s' expected, but '%s' found.", $decoded->iss, self::SERVICE_ID)));
         }
         //---
         $time = time();
         // iat must be a recent timestamp.
         if ($decoded->iat < $time - 10 || $decoded->iat > $time + 10) {
             throw new FailureException(sprintf(sprintf("Unable to validate iat claim. %d expected to be within ten seconds of %d.", $decoded->iat, $time)));
         }
         return true;
     }, 'beInvalidJWSToken' => function ($token) {
         /**
          * Returns true when the JWT throws a SignatureInvalidException.
          */
         try {
             JWT::$leeway = 5;
             // $leeway in seconds
             JWT::decode($token, self::API_KEY, array('HS256'));
         } catch (SignatureInvalidException $e) {
             return true;
         }
         throw new FailureException('Invalid token expected, but the one passed appears valid.');
     }];
 }
開發者ID:alphagov,項目名稱:notifications-php-client,代碼行數:48,代碼來源:JsonWebTokenSpec.php

示例13: jwt

 protected function jwt($payload = array())
 {
     global $_JWTConf;
     //fmt
     $jwt = null;
     $jdata = array('iat' => $_JWTConf['issuedAt'], 'jti' => $_JWTConf['tokenId'], 'iss' => $_JWTConf['issuer'], 'nbf' => $_JWTConf['notBefore'], 'exp' => $_JWTConf['expire'], 'payload' => $payload);
     try {
         //set gracefully
         JWT::$leeway = JWT_LEEWAT_TS;
         //try to munge
         $jwt = JWT::encode($jdata, $_JWTConf['secretKey']);
         @header('X-WWW-Authenticate: Basic realm="Ldap-API Secured Area"');
         @header('X-Authorization: Bearer ' . $jwt);
         //remove
         JWT::$leeway = 0;
         debug("jwt() : [INFO] {$jwt};");
     } catch (\Firebase\JWT\BeforeValidException $e) {
         debug("jwt() : [BeforeValidException]" . $e->getMessage());
     } catch (\Firebase\JWT\ExpiredException $e) {
         debug("jwt() : [ExpiredException]" . $e->getMessage());
     } catch (\Firebase\JWT\SignatureInvalidException $e) {
         debug("jwt() : [SignatureInvalidException]" . $e->getMessage());
     } catch (Exception $e) {
         debug("jwt() : [Exception]" . $e->getMessage());
     }
     //give it back
     return $jwt;
 }
開發者ID:bayugyug,項目名稱:mobile-web-service,代碼行數:28,代碼來源:class-ldap-api.php

示例14: decode

 /**
  * Decode jwt token string
  * @param string $token
  * @return object|bool
  * @throws Exception
  */
 public function decode($token)
 {
     JWT::$leeway = $this->leeway;
     try {
         $payload = JWT::decode($token, $this->key, [$this->algorithm]);
     } catch (Exception $e) {
         return false;
     }
     // ensure that iss, aud, and csrf are good
     $tokenDefaults = $this->getTokenDefaults();
     if ($payload->iss != $tokenDefaults["iss"] || $payload->aud != $tokenDefaults["aud"]) {
         return false;
     }
     if (!empty($payload->csrf) && !$this->request->validateCsrfToken($payload->csrf)) {
         return false;
     }
     return $payload;
 }
開發者ID:amnah,項目名稱:yii2-angular,代碼行數:24,代碼來源:JwtAuth.php

示例15: testInvalidTokenWithIatLeeway

 public function testInvalidTokenWithIatLeeway()
 {
     JWT::$leeway = 60;
     $payload = array("message" => "abc", "iat" => time() + 65);
     // issued too far in future
     $encoded = JWT::encode($payload, 'my_key');
     $this->setExpectedException('Firebase\\JWT\\BeforeValidException');
     $decoded = JWT::decode($encoded, 'my_key', array('HS256'));
     JWT::$leeway = 0;
 }
開發者ID:furesoft,項目名稱:php-jwt,代碼行數:10,代碼來源:JWTTest.php


注:本文中的Firebase\JWT\JWT::leeway方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。