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


PHP JWT::urlsafeB64Encode方法代碼示例

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


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

示例1: encode

 /**
  * Converts and signs a PHP object or array into a JWT string.
  *
  * @param object|array  $payload    PHP object or array
  * @param string        $key        The secret key.
  *                                  If the algorithm used is asymmetric, this is the private key
  * @param string        $alg        The signing algorithm.
  *                                  Supported algorithms are 'HS256', 'HS384', 'HS512' and 'RS256'
  * @param array         $head       An array with header elements to attach
  *
  * @return string A signed JWT
  *
  * @uses jsonEncode
  * @uses urlsafeB64Encode
  */
 public static function encode($payload, $key, $alg = 'HS256', $keyId = null, $head = null)
 {
     $header = array('typ' => 'JWT', 'alg' => $alg);
     if ($keyId !== null) {
         $header['kid'] = $keyId;
     }
     if (isset($head) && is_array($head)) {
         $header = array_merge($head, $header);
     }
     $segments = array();
     $segments[] = JWT::urlsafeB64Encode(JWT::jsonEncode($header));
     $segments[] = JWT::urlsafeB64Encode(JWT::jsonEncode($payload));
     $signing_input = implode('.', $segments);
     $signature = JWT::sign($signing_input, $key, $alg);
     $segments[] = JWT::urlsafeB64Encode($signature);
     return implode('.', $segments);
 }
開發者ID:ivyhappy,項目名稱:PHYMAN,代碼行數:32,代碼來源:JWT.php

示例2: DateTime

    if (!isset($server['PHP_AUTH_USER'], $server['PHP_AUTH_PW'])) {
        return $this->api->json($res, ['error' => 'BadArguments', 'message' => 'You need to give a username and a password'], 400);
    }
    $username = $server['PHP_AUTH_USER'];
    $password = $server['PHP_AUTH_PW'];
    if (!($user = $users->read($username))) {
        return $this->api->json($res, ['error' => 'BadCredentials', 'message' => 'User or password not ok'], 403);
    }
    if (!$user->login($password)) {
        return $this->api->json($res, ['error' => 'BadCredentials', 'message' => 'User or password not ok'], 403);
    }
    $now = new DateTime();
    $future = new DateTime('now +2 hours');
    $server = $req->getServerParams();
    try {
        $payload = ['iat' => $now->getTimeStamp(), 'exp' => $future->getTimeStamp(), 'jti' => JWT::urlsafeB64Encode(random_bytes(32)), 'sub' => $username, 'scope' => $user->getRoles()];
    } catch (Exception $e) {
        die('Could not generate a random string. Is our OS secure?');
    }
    $secret = $app['config']->get('secretToken');
    $token = JWT::encode($payload, $secret, 'HS256');
    $data['status'] = 'ok';
    $data['token'] = $token;
    return $res->withStatus(201)->withHeader('Content-Type', 'application/json')->write(json_encode($data, JSON_UNESCAPED_SLASHES | JSON_PRETTY_PRINT));
});
$this->get('/credentials', function ($req, $res) {
    if (!isset($this->token)) {
        return $res->withStatus(401)->withJson([]);
    }
    $res->withJson($this->token->scope);
});
開發者ID:bafs,項目名稱:parvula,代碼行數:31,代碼來源:index.php


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