# jwt
```
<pre class="calibre15">```
<span class="token"><</span><span class="token">?</span>php
<span class="token6">/**
* PHP實現jwt
*/</span>
class <span class="token3">Jwt</span> <span class="token1">{</span>
<span class="token6">//頭部</span>
private static $header<span class="token">=</span><span class="token3">array</span><span class="token1">(</span>
<span class="token4">'alg'</span><span class="token">=</span><span class="token">></span><span class="token4">'HS256'</span><span class="token1">,</span> <span class="token6">//生成signature的算法</span>
<span class="token4">'typ'</span><span class="token">=</span><span class="token">></span><span class="token4">'JWT'</span> <span class="token6">//類型</span>
<span class="token1">)</span><span class="token1">;</span>
<span class="token6">//使用HMAC生成信息摘要時所使用的密鑰</span>
private static $key<span class="token">=</span><span class="token4">'123456'</span><span class="token1">;</span>
<span class="token6">/**
* 獲取jwt token
* @param array $payload jwt載荷 格式如下非必須
* [
* 'iss'=>'jwt_admin', //該JWT的簽發者
* 'iat'=>time(), //簽發時間
* 'exp'=>time()+7200, //過期時間
* 'nbf'=>time()+60, //該時間之前不接收處理該Token
* 'sub'=>'www.admin.com', //面向的用戶
* 'jti'=>md5(uniqid('JWT').time()) //該Token唯一標識
* ]
* @return bool|string
*/</span>
public static <span class="token2">function</span> <span class="token3">getToken</span><span class="token1">(</span>array $payload<span class="token1">)</span>
<span class="token1">{</span>
<span class="token2">if</span><span class="token1">(</span><span class="token3">is_array</span><span class="token1">(</span>$payload<span class="token1">)</span><span class="token1">)</span>
<span class="token1">{</span>
$base64header<span class="token">=</span>self<span class="token1">:</span><span class="token1">:</span><span class="token3">base64UrlEncode</span><span class="token1">(</span><span class="token3">json_encode</span><span class="token1">(</span>self<span class="token1">:</span><span class="token1">:</span>$header<span class="token1">,</span>JSON_UNESCAPED_UNICODE<span class="token1">)</span><span class="token1">)</span><span class="token1">;</span>
$base64payload<span class="token">=</span>self<span class="token1">:</span><span class="token1">:</span><span class="token3">base64UrlEncode</span><span class="token1">(</span><span class="token3">json_encode</span><span class="token1">(</span>$payload<span class="token1">,</span>JSON_UNESCAPED_UNICODE<span class="token1">)</span><span class="token1">)</span><span class="token1">;</span>
$token<span class="token">=</span>$base64header<span class="token1">.</span><span class="token4">'.'</span><span class="token1">.</span>$base64payload<span class="token1">.</span><span class="token4">'.'</span><span class="token1">.</span>self<span class="token1">:</span><span class="token1">:</span><span class="token3">signature</span><span class="token1">(</span>$base64header<span class="token1">.</span><span class="token4">'.'</span><span class="token1">.</span>$base64payload<span class="token1">,</span>self<span class="token1">:</span><span class="token1">:</span>$key<span class="token1">,</span>self<span class="token1">:</span><span class="token1">:</span>$header<span class="token1">[</span><span class="token4">'alg'</span><span class="token1">]</span><span class="token1">)</span><span class="token1">;</span>
<span class="token2">return</span> $token<span class="token1">;</span>
<span class="token1">}</span><span class="token2">else</span><span class="token1">{</span>
<span class="token2">return</span> <span class="token5">false</span><span class="token1">;</span>
<span class="token1">}</span>
<span class="token1">}</span>
<span class="token6">/**
* 驗證token是否有效,默認驗證exp,nbf,iat時間
* @param string $Token 需要驗證的token
* @return bool|string
*/</span>
public static <span class="token2">function</span> <span class="token3">verifyToken</span><span class="token1">(</span>string $Token<span class="token1">)</span>
<span class="token1">{</span>
$tokens <span class="token">=</span> <span class="token3">explode</span><span class="token1">(</span><span class="token4">'.'</span><span class="token1">,</span> $Token<span class="token1">)</span><span class="token1">;</span>
<span class="token2">if</span> <span class="token1">(</span><span class="token3">count</span><span class="token1">(</span>$tokens<span class="token1">)</span> <span class="token">!=</span> <span class="token5">3</span><span class="token1">)</span>
<span class="token2">return</span> <span class="token5">false</span><span class="token1">;</span>
<span class="token3">list</span><span class="token1">(</span>$base64header<span class="token1">,</span> $base64payload<span class="token1">,</span> $sign<span class="token1">)</span> <span class="token">=</span> $tokens<span class="token1">;</span>
<span class="token6">//獲取jwt算法</span>
$base64decodeheader <span class="token">=</span> <span class="token3">json_decode</span><span class="token1">(</span>self<span class="token1">:</span><span class="token1">:</span><span class="token3">base64UrlDecode</span><span class="token1">(</span>$base64header<span class="token1">)</span><span class="token1">,</span> JSON_OBJECT_AS_ARRAY<span class="token1">)</span><span class="token1">;</span>
<span class="token2">if</span> <span class="token1">(</span><span class="token3">empty</span><span class="token1">(</span>$base64decodeheader<span class="token1">[</span><span class="token4">'alg'</span><span class="token1">]</span><span class="token1">)</span><span class="token1">)</span>
<span class="token2">return</span> <span class="token5">false</span><span class="token1">;</span>
<span class="token6">//簽名驗證</span>
<span class="token2">if</span> <span class="token1">(</span>self<span class="token1">:</span><span class="token1">:</span><span class="token3">signature</span><span class="token1">(</span>$base64header <span class="token1">.</span> <span class="token4">'.'</span> <span class="token1">.</span> $base64payload<span class="token1">,</span> self<span class="token1">:</span><span class="token1">:</span>$key<span class="token1">,</span> $base64decodeheader<span class="token1">[</span><span class="token4">'alg'</span><span class="token1">]</span><span class="token1">)</span> <span class="token">!==</span> $sign<span class="token1">)</span>
<span class="token2">return</span> <span class="token5">false</span><span class="token1">;</span>
$payload <span class="token">=</span> <span class="token3">json_decode</span><span class="token1">(</span>self<span class="token1">:</span><span class="token1">:</span><span class="token3">base64UrlDecode</span><span class="token1">(</span>$base64payload<span class="token1">)</span><span class="token1">,</span> JSON_OBJECT_AS_ARRAY<span class="token1">)</span><span class="token1">;</span>
<span class="token6">//簽發時間大于當前服務器時間驗證失敗</span>
<span class="token2">if</span> <span class="token1">(</span><span class="token3">isset</span><span class="token1">(</span>$payload<span class="token1">[</span><span class="token4">'iat'</span><span class="token1">]</span><span class="token1">)</span> <span class="token">&&</span> $payload<span class="token1">[</span><span class="token4">'iat'</span><span class="token1">]</span> <span class="token">></span> <span class="token3">time</span><span class="token1">(</span><span class="token1">)</span><span class="token1">)</span>
<span class="token2">return</span> <span class="token5">false</span><span class="token1">;</span>
<span class="token6">//過期時間小宇當前服務器時間驗證失敗</span>
<span class="token2">if</span> <span class="token1">(</span><span class="token3">isset</span><span class="token1">(</span>$payload<span class="token1">[</span><span class="token4">'exp'</span><span class="token1">]</span><span class="token1">)</span> <span class="token">&&</span> $payload<span class="token1">[</span><span class="token4">'exp'</span><span class="token1">]</span> <span class="token"><</span> <span class="token3">time</span><span class="token1">(</span><span class="token1">)</span><span class="token1">)</span>
<span class="token2">return</span> <span class="token5">false</span><span class="token1">;</span>
<span class="token6">//該nbf時間之前不接收處理該Token</span>
<span class="token2">if</span> <span class="token1">(</span><span class="token3">isset</span><span class="token1">(</span>$payload<span class="token1">[</span><span class="token4">'nbf'</span><span class="token1">]</span><span class="token1">)</span> <span class="token">&&</span> $payload<span class="token1">[</span><span class="token4">'nbf'</span><span class="token1">]</span> <span class="token">></span> <span class="token3">time</span><span class="token1">(</span><span class="token1">)</span><span class="token1">)</span>
<span class="token2">return</span> <span class="token5">false</span><span class="token1">;</span>
<span class="token2">return</span> $payload<span class="token1">;</span>
<span class="token1">}</span>
<span class="token6">/**
* base64UrlEncode https://jwt.io/ 中base64UrlEncode編碼實現
* @param string $input 需要編碼的字符串
* @return string
*/</span>
private static <span class="token2">function</span> <span class="token3">base64UrlEncode</span><span class="token1">(</span>string $input<span class="token1">)</span>
<span class="token1">{</span>
<span class="token2">return</span> <span class="token3">str_replace</span><span class="token1">(</span><span class="token4">'='</span><span class="token1">,</span> <span class="token4">''</span><span class="token1">,</span> <span class="token3">strtr</span><span class="token1">(</span><span class="token3">base64_encode</span><span class="token1">(</span>$input<span class="token1">)</span><span class="token1">,</span> <span class="token4">'+/'</span><span class="token1">,</span> <span class="token4">'-_'</span><span class="token1">)</span><span class="token1">)</span><span class="token1">;</span>
<span class="token1">}</span>
<span class="token6">/**
* base64UrlEncode https://jwt.io/ 中base64UrlEncode解碼實現
* @param string $input 需要解碼的字符串
* @return bool|string
*/</span>
private static <span class="token2">function</span> <span class="token3">base64UrlDecode</span><span class="token1">(</span>string $input<span class="token1">)</span>
<span class="token1">{</span>
$remainder <span class="token">=</span> <span class="token3">strlen</span><span class="token1">(</span>$input<span class="token1">)</span> <span class="token">%</span> <span class="token5">4</span><span class="token1">;</span>
<span class="token2">if</span> <span class="token1">(</span>$remainder<span class="token1">)</span> <span class="token1">{</span>
$addlen <span class="token">=</span> <span class="token5">4</span> <span class="token">-</span> $remainder<span class="token1">;</span>
$input <span class="token1">.</span><span class="token">=</span> <span class="token3">str_repeat</span><span class="token1">(</span><span class="token4">'='</span><span class="token1">,</span> $addlen<span class="token1">)</span><span class="token1">;</span>
<span class="token1">}</span>
<span class="token2">return</span> <span class="token3">base64_decode</span><span class="token1">(</span><span class="token3">strtr</span><span class="token1">(</span>$input<span class="token1">,</span> <span class="token4">'-_'</span><span class="token1">,</span> <span class="token4">'+/'</span><span class="token1">)</span><span class="token1">)</span><span class="token1">;</span>
<span class="token1">}</span>
<span class="token6">/**
* HMACSHA256簽名 https://jwt.io/ 中HMACSHA256簽名實現
* @param string $input 為base64UrlEncode(header).".".base64UrlEncode(payload)
* @param string $key
* @param string $alg 算法方式
* @return mixed
*/</span>
private static <span class="token2">function</span> <span class="token3">signature</span><span class="token1">(</span>string $input<span class="token1">,</span> string $key<span class="token1">,</span> string $alg <span class="token">=</span> <span class="token4">'HS256'</span><span class="token1">)</span>
<span class="token1">{</span>
$alg_config<span class="token">=</span><span class="token3">array</span><span class="token1">(</span>
<span class="token4">'HS256'</span><span class="token">=</span><span class="token">></span><span class="token4">'sha256'</span>
<span class="token1">)</span><span class="token1">;</span>
<span class="token2">return</span> self<span class="token1">:</span><span class="token1">:</span><span class="token3">base64UrlEncode</span><span class="token1">(</span><span class="token3">hash_hmac</span><span class="token1">(</span>$alg_config<span class="token1">[</span>$alg<span class="token1">]</span><span class="token1">,</span> $input<span class="token1">,</span> $key<span class="token1">,</span><span class="token5">true</span><span class="token1">)</span><span class="token1">)</span><span class="token1">;</span>
<span class="token1">}</span>
<span class="token1">}</span>
<span class="token6">//測試和官網是否匹配begin</span>
$payload<span class="token">=</span><span class="token3">array</span><span class="token1">(</span><span class="token4">'sub'</span><span class="token">=</span><span class="token">></span><span class="token4">'1234567890'</span><span class="token1">,</span><span class="token4">'name'</span><span class="token">=</span><span class="token">></span><span class="token4">'John Doe'</span><span class="token1">,</span><span class="token4">'iat'</span><span class="token">=</span><span class="token">></span><span class="token5">1516239022</span><span class="token1">)</span><span class="token1">;</span>
$jwt<span class="token">=</span><span class="token2">new</span> <span class="token3">Jwt</span><span class="token1">;</span>
$token<span class="token">=</span>$jwt<span class="token">-</span><span class="token">></span><span class="token3">getToken</span><span class="token1">(</span>$payload<span class="token1">)</span><span class="token1">;</span>
echo <span class="token4">""</span><span class="token1">;</span>
echo $token<span class="token1">;</span>
<span class="token6">//對token進行驗證簽名</span>
$getPayload<span class="token">=</span>$jwt<span class="token">-</span><span class="token">></span><span class="token3">verifyToken</span><span class="token1">(</span>$token<span class="token1">)</span><span class="token1">;</span>
echo <span class="token4">"<br><br>"</span><span class="token1">;</span>
<span class="token3">var_dump</span><span class="token1">(</span>$getPayload<span class="token1">)</span><span class="token1">;</span>
echo <span class="token4">"<br><br>"</span><span class="token1">;</span>
<span class="token6">//測試和官網是否匹配end</span>
<span class="token6">//自己使用測試begin</span>
$payload_test<span class="token">=</span><span class="token3">array</span><span class="token1">(</span><span class="token4">'iss'</span><span class="token">=</span><span class="token">></span><span class="token4">'admin'</span><span class="token1">,</span><span class="token4">'iat'</span><span class="token">=</span><span class="token">></span><span class="token3">time</span><span class="token1">(</span><span class="token1">)</span><span class="token1">,</span><span class="token4">'exp'</span><span class="token">=</span><span class="token">></span><span class="token3">time</span><span class="token1">(</span><span class="token1">)</span><span class="token">+</span><span class="token5">7200</span><span class="token1">,</span><span class="token4">'nbf'</span><span class="token">=</span><span class="token">></span><span class="token3">time</span><span class="token1">(</span><span class="token1">)</span><span class="token1">,</span><span class="token4">'sub'</span><span class="token">=</span><span class="token">></span><span class="token4">'www.admin.com'</span><span class="token1">,</span><span class="token4">'jti'</span><span class="token">=</span><span class="token">></span><span class="token3">md5</span><span class="token1">(</span><span class="token3">uniqid</span><span class="token1">(</span><span class="token4">'JWT'</span><span class="token1">)</span><span class="token1">.</span><span class="token3">time</span><span class="token1">(</span><span class="token1">)</span><span class="token1">)</span><span class="token1">)</span><span class="token1">;</span><span class="token1">;</span>
$token_test<span class="token">=</span>Jwt<span class="token1">:</span><span class="token1">:</span><span class="token3">getToken</span><span class="token1">(</span>$payload_test<span class="token1">)</span><span class="token1">;</span>
echo <span class="token4">""</span><span class="token1">;</span>
echo $token_test<span class="token1">;</span>
<span class="token6">//對token進行驗證簽名</span>
$getPayload_test<span class="token">=</span>Jwt<span class="token1">:</span><span class="token1">:</span><span class="token3">verifyToken</span><span class="token1">(</span>$token_test<span class="token1">)</span><span class="token1">;</span>
echo <span class="token4">"<br><br>"</span><span class="token1">;</span>
<span class="token3">var_dump</span><span class="token1">(</span>$getPayload_test<span class="token1">)</span><span class="token1">;</span>
echo <span class="token4">"<br><br>"</span><span class="token1">;</span>
<span class="token6">//自己使用時候end</span>
```
```
- fastadmin教程
- fastadmin原始分類的操作方法
- fastadmin關聯官方和自方法修改
- fastadmin下拉搜索異步
- fastadmin 語法解釋
- fastadmin 一對多和in的用法以及搜索方法
- fasttadmin表格
- xdebug的安裝和使用在phpstorm
- thinkphp教程
- thinkphp 一對多 多對一的源碼實例
- thinkphp跨域的解決辦法
- thinkphp使用redis
- thinkphp常用判斷語句
- thinkphp的顯示更新 自動判斷是否需要更新
- thinkphp5一對多或者多對一
- thinkphp5方法注入
- thinkphp map回調函數用法
- thinkphp6.0數據庫上
- thinkphp6.0數據庫下
- thinkphp6.0模型關聯
- 命令行操作MYSQL
- thinkphp6.0依賴注入 容器 門面
- thinkphp6 偽靜態參數綁定開啟緩存
- Mysql 索引教程
- mysql 索引其他知識
- desc(降序)asc(升序) inc(自增) dec(自減)
- 什么是ORM?為什么要用ORM?
- thinkphp操作mysql部分
- thinkphp的自動加載
- thinkphp5.1中的配置文件
- thinkphp5.1容器和門面模式
- tp5 單例模式
- 注冊樹模式
- 依賴注入
- 反射機制(補充部分內容)
- Countable的使用
- 簡單Contaniner容器
- thinkphp5.1容器流程分析
- thinkphp6中間件
- thinkphp6 Facade門面
- thinkphp中間件
- 導航菜單遞歸
- 圖片轉base64
- php教程
- php序列化和反序列化解析
- php封裝POST或者GET請求
- 字符串轉換成數組
- 帝國CMS常用函數
- php操作Memcached對象
- php操作fetch
- 帝國cms所有數據庫字段說明
- [優化sql提高查詢速度]
- 深入分析PHP優化及注意事項
- MySQL性能優化的最佳21條經驗
- MySQL全文索引Match Against與Like比較
- mysql常用記錄
- php curl
- php截取字符串
- php字符串處理
- php 13位時間戳
- php操作數據庫
- php對接碼支付
- php常用概念
- php 構造函數和析構函數的區別
- PHP的join的用法
- mysql 索引教程
- php 數組處理
- php 閉包傳值
- RBAC權限管理
- php -- 取路徑:getcwd()、DIR、FILE 的區別
- php字符串下標
- jwt
- uni-app教程
- uniapp頁面跳轉
- uniaapp文件配置目錄
- uniapp引入ui組件
- uniapp引入全局變量
- uniapp頁面傳參
- uniapp從接口獲取數據
- uniapp制作驗證碼倒計時定時器
- uniapp 同步上傳圖片
- uniapp時間戳改成正常時間
- uniapp目錄的作用
- 小數四舍五入縮短小數位數
- 自定義tarbar
- uniapp頁面通訊
- uniapp之this作用域
- 關閉側滑
- 開發概念講解
- 跨域概念
- 微信QQ等手機UA
- autojs懸浮窗以及url訪問
- python3 使用flak開發網站
- python3怎么用sqlalchemy操作mysql
- python3使用alchemy操作mysql完成代碼
- python使用alchemy處理一對一和反向引用
- python3 sqlalchemy 一對一關系
- flask中使用sqlalchemy處理多對多
- flask_script插件的使用
- javascript教程
- jq制作定時器
- 右側懸浮彈窗可關閉
- jq ajax請求
- prototype
- toLowerCase()基本使用
- Array數組的join()方法
- javascript回調函數詳解
- jquery中$.ajax()方法使用詳解
- js中的回調函數
- js中every和some的區別
- js實現本地搜索
- html本地傳輸數據
- 前端CSS教程
- css rem單位 em單位 和定位
- 自適應
- 前端定位方式
- flex布局下img圖片變形的解決方法
- css樣式代碼段
- css居中
- position和display和float區別
- css工具或者導航
- border邊框
- 正則表達式
- 匹配鍵盤可見特殊符號
- 微信小程序教程
- 微信小程序整理
- 小程序開發框架
- 小程序支付
- 微信小程序自定義組件
- 微信小程序配置文件介紹
- 模塊化
- 視圖層
- centos linux 圖文教程
- centos easyswoole
- es6教程
- ES6 let 與 const
- ES6 解構賦值
- ES6 Symbol
- ES6 Map 與 Set
- ES6 Reflect 與 Proxy
- ES6 字符串
- ES6中循環
- ES6函數的擴展
- ES6模塊
- ES6 class類
- promise 對象
- async和await
- ES6對象屬性簡寫
- object.assign基本用法
- object.keys()基本用法
- es6展開運算符
- es6的導入導出方式
- 織夢cms
- 不同的分類顯示不同的圖片
- 正則表達式php教程
- git基本使用教程
- git 清空緩存
- nodeJS
- nodejs 會話技術
- 網絡爬蟲
- nodejs操作數據庫
- nodejs中resolve()在url中的使用方法
- nvm node版本管理工具
- nrm
- npm安裝的區別
- Buffer類
- Vue教程
- VUE安裝
- vue腳手架
- vue創建路由
- Vuex
- vue懶加載
- axios網絡請求
- ES6 Promise 對象
- ES6 async 函數
- vue綁定元素
- vue回調函數的理解
- indexof()
- vue生命周期
- router-view和keep-alive
- Mustache插值操作
- 計算屬性 computed
- Locker實現localStrage的簡便方法
- this.$router.push replace go的用法
- vue中使用refs 完成密碼框明密文切換
- 計算屬性和method的對比
- 父子組件之間的通信
- vue中路由的基本使用
- $router和$route的區別
- prototype 原型的使用
- vue的導航守衛
- vue的生命周期
- vue 路由hash改成history
- vue中路由詳解
- vue中的回調函數
- slot插槽
- vuecli3 跨域
- vue和thinkphp中的前端設置代理跨域
- js中push pop unshift shift的區別
- 計算屬性computed如何傳參
- vue或uniapp中this.$set()時的語法格式
- 計算屬性 vs 偵聽屬性 watch
- elementui片段
- vue修飾符
- vue---reduce高級與filter去重
- indexOf 和 includes
- require.context()的用法
- vite構建
- vue3.2新特性
- axios封裝中間件和避免重復請求
- vue-router 4.x筆記
- Redis基本教程
- laravel基本教程
- 路由
- 視圖
- 模型
- 創建數據表和操作數據庫
- windows服務器清理mysql殘留
- mysql語句
- mysql 語句整理一
- mysql概念和性能優化
- mysql常用工作遇到
- mysql
- mysql 5.7 groupby
- implode()和explode()
- mysql語句部分
- Mysql使用函數json_extract處理Json類型數據
- linux 基礎教程
- linux常用命令
- linux 安裝redis
- linux 安裝nodejs
- linux軟連接的創建 刪除和修改
- pm2使用方法
- linux 編譯和安裝軟件包
- linux操作用戶
- centos8安裝mysql5.7
- vscode操作eslint用法
- Docker教程
- JAVA
- implements Serializable的作用
- mac系統操作教程
- mac安裝redis擴展
- 升級mac自帶的php版本
- brew
- 占用端口
- GO筆記整理
- 目錄結構
- 下劃線
- 變量
- 切片
- 指針
- map
- 匿名字段
- nil含義
- socket
- 并發
- goroutine調度
- 管道
- GO正則表達式
- iota
- go moudles
- go 中函數的對比
- golang 參數傳值
- Casbin
- 基本類型
- 實例化結構體
- 原生sql設置變量
- ------代碼片段-------
- uniapp
- uniapp樣式
- uniapp上傳
- vue封裝html轉成excel
- yyladmin
- array_merge
- vuex部分
- vue前端部分
- yyladmin前端安裝流程
- windows安裝linux子系統
- yum和apt的區別