濮阳杆衣贸易有限公司

主頁 > 知識庫 > PHP JWT初識及其簡單示例

PHP JWT初識及其簡單示例

熱門標(biāo)簽:電信外呼系統(tǒng)多少錢一個月 企業(yè)400電話辦理多少費用 宿州正規(guī)外呼系統(tǒng)軟件 代理打電話機器人 神龍斗士電話機器人 桂陽公司如何做地圖標(biāo)注 萍鄉(xiāng)商鋪地圖標(biāo)注 合肥企業(yè)外呼系統(tǒng)線路 太原400電話申請流程

一直沒有好好看過jwt,直到前兩天要做web驗證,朋友給我推薦了jwt。才發(fā)現(xiàn)jwt已經(jīng)被大家廣泛的應(yīng)用了。看來我有點out了。哈哈,趁著這個世界來好好看看這個。

JWT(JSON Web Token), 顧名思義就是可以在Web上傳輸?shù)膖oken,這種token是用JSON格式進行format的。它是一個開源標(biāo)準(zhǔn)(RFC 7519),定義了一個緊湊的自包含的方式在不同實體之間安全的用JSON格式傳輸信息。

由于現(xiàn)在很多項目都是前后端分離,restful api模式。所以傳統(tǒng)的session模式就沒有辦法滿足認(rèn)證需求,這個時候jwt的作用就來了。可以說 restful api認(rèn)證是jwt的一個很好的應(yīng)用場景。

參數(shù)解釋

名稱 解釋
iss (issuer) issuer 請求實體,可以是發(fā)起請求的用戶的信息,也可是jwt的簽發(fā)者
sub (Subject) 設(shè)置主題,類似于發(fā)郵件時的主題
aud (audience) 接收jwt的一方
exp (expire) token過期時間
nbf (not before) 當(dāng)前時間在nbf設(shè)定時間之前,該token無法使用
iat (issued at) token創(chuàng)建時間
jti (JWT ID) 對當(dāng)前token設(shè)置唯一標(biāo)示

下面是一個很小的demo

?php
require_once 'src/JWT.php';
header('Content-type:application/json');
//定義Key
const KEY = 'dasjdkashdwqe1213dsfsn;p';

$user = [
  'uid'=>'dadsa-12312-vsd1s1-fsds',
  'account'=>'daisc',
  'password'=>'123456'
];
$redis = redis();
$action = $_GET['action'];
switch ($action)
{
  case 'login':
    login();
    break;
  case 'info':
    info();
    break;

}
//登陸,寫入驗證token
function login()
{
  global $user;
  $account = $_GET['account'];
  $pwd = $_GET['password'];
  $res = [];
  if($account==$user['account']$pwd==$user['password'])
  {
    unset($user['password']);
    $time = time();
    $token = [
      'iss'=>'http://test.cc',//簽發(fā)者
      'iat'=>$time,
      'exp'=>$time+60,
      'data'=>$user
    ];
    $jwt = \Firebase\JWT\JWT::encode($token,KEY);
    $res['code'] = 200;
    $res['message'] = '登錄成功';
    $res['jwt'] = $jwt;

  }
  else
  {
    $res['message']= '用戶名或密碼錯誤';
    $res['code'] = 401;
  }
  exit(json_encode($res));
}

function info()
{
  $jwt = $_SERVER['HTTP_AUTHORIZATION'] ?? false;
  $res['code'] = 200;
  if($jwt)
  {
    $jwt = str_replace('Bearer ','',$jwt);
    if(empty($jwt))
    {
      $res['code'] = 401;
      $res['msg'] = 'You do not have permission to access.';
      exit(json_encode($res));
    }
    try{
      $token = (array) \Firebase\JWT\JWT::decode($jwt,KEY, ['HS256']);
      if($token['exp']time())
      {
        $res['code'] = 401;
        $res['msg'] = '登錄超時,請重新登錄';
      }
      $res['data']= $token['data'];
    }catch (\Exception $E)
    {
      $res['code'] = 401;
      $res['msg'] = '登錄超時,請重新登錄.';
    }
  }
  else
  {
    $res['code'] = 401;
    $res['msg'] = 'You do not have permission to access.';
  }
  exit(json_encode($res));
}

//連接redis
function redis()
{
  $redis = new Redis();
  $redis->connect('127.0.0.1');
  return $redis;
}

這個dmeo里面用jwt做了一個簡單的認(rèn)證。 其中用到了一個php-jwt的加密包https://github.com/firebase/php-jwt

其中KEY為定義的私鑰也就是jwt里面的 sign部分,這個一定要保存好。
而header部分php-jwt包里面已經(jīng)幫我們完成了,加密代碼如下

  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[] = static::urlsafeB64Encode(static::jsonEncode($header));
    $segments[] = static::urlsafeB64Encode(static::jsonEncode($payload));
    $signing_input = implode('.', $segments);

    $signature = static::sign($signing_input, $key, $alg);
    $segments[] = static::urlsafeB64Encode($signature);

    return implode('.', $segments);
  }

可以看出默認(rèn)的加密的方式是HS256。這也是說jwt安全的原因?,F(xiàn)階段HS256加密還是很安全的。
這個包里面也支持證書加密。

加密解密的過程這個包已經(jīng)幫我們完成了。所以我們只需要定義jwt中的 poyload部分就可以了。也就是demo里面的token部分。加密成功會得到一個加密的Jwt字符串,下次前端在請求api的時候需要攜帶這個jwt字符串作為認(rèn)證。
在header頭里面增加Authorization。在服務(wù)端驗證的時候回通過取得這個值來驗證回話的有效。

下面是poyload的一些常用配置

 $token  = [
      #非必須。issuer 請求實體,可以是發(fā)起請求的用戶的信息,也可是jwt的簽發(fā)者。
      "iss"    => "http://example.org",
      #非必須。issued at。 token創(chuàng)建時間,unix時間戳格式
      "iat"    => $_SERVER['REQUEST_TIME'],
      #非必須。expire 指定token的生命周期。unix時間戳格式
      "exp"    => $_SERVER['REQUEST_TIME'] + 7200,
      #非必須。接收該JWT的一方。
      "aud"    => "http://example.com",
      #非必須。該JWT所面向的用戶
      "sub"    => "jrocket@example.com",
      # 非必須。not before。如果當(dāng)前時間在nbf里的時間之前,則Token不被接受;一般都會留一些余地,比如幾分鐘。
      "nbf"    => 1357000000,
      # 非必須。JWT ID。針對當(dāng)前token的唯一標(biāo)識
      "jti"    => '222we',
      # 自定義字段
      "GivenName" => "Jonny",
      # 自定義字段
      "name"  => "Rocket",
      # 自定義字段
      "Email"   => "jrocket@example.com",
     
    ];

里面包含的配置可以自由配置,也可以自己添加一些其他的。這些都是網(wǎng)上大家常用的,可以說是一種約定吧。

注意事項

關(guān)于jwt的使用大概就是這些。上面的代碼在你使用的時候可能會出現(xiàn)兩個問題:

1、命名空間錯誤
解決:不使用命名空間的話,使用require引入文件。如果使用命名空間出現(xiàn)錯誤,請檢查命名空間的路徑。

2、生成的token是一個對象
解決:(string)$token 將token強轉(zhuǎn)成string

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • php 后端實現(xiàn)JWT認(rèn)證方法示例
  • php實現(xiàn)JWT(json web token)鑒權(quán)實例詳解
  • php JWT在web端中的使用方法教程
  • PHP如何使用JWT做Api接口身份認(rèn)證的實現(xiàn)
  • php實現(xiàn)JWT驗證的實例教程

標(biāo)簽:辛集 太原 白銀 崇左 衡陽 鄂州 廊坊 綏化

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP JWT初識及其簡單示例》,本文關(guān)鍵詞  PHP,JWT,初識,及其,簡單,示例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP JWT初識及其簡單示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP JWT初識及其簡單示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    吉林市| 石泉县| 连云港市| 大田县| 济宁市| 靖江市| 乡宁县| 景宁| 繁峙县| 黔西| 凤山县| 锡林浩特市| 定远县| 渝北区| 凤城市| 洞口县| 临夏县| 嘉荫县| 荣成市| 普宁市| 凤凰县| 永胜县| 平塘县| 壤塘县| 青川县| 徐州市| 宁化县| 彭州市| 米易县| 湘潭市| 桦南县| 怀柔区| 海丰县| 玉山县| 木里| 酉阳| 开原市| 嘉义县| 锦州市| 广饶县| 武穴市|