亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

ThinkPHP6使用JWT+中間件實(shí)現(xiàn)Token驗(yàn)證實(shí)例詳解

瀏覽:143日期:2022-06-13 17:40:47
前言

最近看了很多關(guān)于TP6使用JWT的文章,總結(jié):按照他們的步驟——幾乎不行,所以準(zhǔn)備自己寫(xiě)一篇偏向?qū)崙?zhàn)的文章,也當(dāng)做個(gè)記錄。

一、JWT介紹

不喜歡搬文章,所以這篇文章,我愿稱他為全網(wǎng)最詳!(里面詳細(xì)介紹了JWT是什么?為什么要用??jī)?yōu)勢(shì)、結(jié)構(gòu)、用法等)

JWT token驗(yàn)證詳解

如果想直接看代碼,請(qǐng)繼續(xù)向下↓

二、使用composer安裝JWT擴(kuò)展包c(diǎn)omposer require firebase/php-jwt

三、在ThinkPHP6中直接使用JWT生成驗(yàn)證Token(簡(jiǎn)單粗暴)(一)代碼文件

(已開(kāi)啟多應(yīng)用模式)

composer require topthink/think-multi-app

common.php:

<?php// 應(yīng)用公共文件use \Firebase\JWT\JWT;use Firebase\JWT\Key;//在這個(gè)類的參數(shù)這里踩了坑,可惡//生成驗(yàn)簽function signToken($data) :string{ $key='LAL@lc!'; //這里是自定義的一個(gè)隨機(jī)字串,應(yīng)該寫(xiě)在config文件中的,解密時(shí)也會(huì)用,相當(dāng)于加密中常用的 鹽-salt $token=array('iss'=>$key,//簽發(fā)者 可以為空'aud'=>'', //面象的用戶,可以為空'iat'=>time(), //簽發(fā)時(shí)間'nbf'=>time()+3, //在什么時(shí)候jwt開(kāi)始生效 (這里表示生成100秒后才生效)'exp'=> time()+7200, //token 過(guò)期時(shí)間'data'=>$data //記錄的userid的信息,這里是自已添加上去的,如果有其它信息,可以再添加數(shù)組的鍵值對(duì) ); return JWT::encode($token, $key, 'HS384'); //根據(jù)參數(shù)生成了token,可選:HS256、HS384、HS512、RS256、ES256等}//驗(yàn)證tokenfunction checkToken($token) :array{ $key='LAL@lc!'; $status=array('code'=>2); try {JWT::$leeway = 60;//當(dāng)前時(shí)間減去60,把時(shí)間留點(diǎn)余地$decoded = JWT::decode($token, new Key($key, 'HS384') ); //同上的方式,這里要和簽發(fā)的時(shí)候?qū)?yīng)$arr = (array)$decoded;$res['code']=200;$res['data']=$arr['data'];$res['data'] = json_decode(json_encode($res['data']),true);//將stdObj類型轉(zhuǎn)換為arrayreturn $res; } catch(\Firebase\JWT\SignatureInvalidException $e) { //簽名不正確$status['msg']='簽名不正確';return $status; }catch(\Firebase\JWT\BeforeValidException $e) { // 簽名在某個(gè)時(shí)間點(diǎn)之后才能用$status['msg']='token失效';return $status; }catch(\Firebase\JWT\ExpiredException $e) { // token過(guò)期$status['msg']='token失效';return $status; }catch(Exception $e) { //其他錯(cuò)誤$status['msg']='未知錯(cuò)誤';return $status; }}

app\index\controller中:index.php

<?phpnamespace app\index\controller;use app\BaseController;use think\facade\Request;use think\response\Json;class Index extends BaseController{ /** * 模擬將數(shù)組類型的數(shù)據(jù)加密然后得到token * @return string */ public function index() :string {$user = ['id'=>521,'openid'=>'123456789'];$user['token'] = signToken($user); return $user['token']; } /** * 解密token的數(shù)據(jù)并返回 * @return Json */ public function checkIt() :Json {$token = Request::header()['token']??false;if(!$token) return json(['code'=>201,'msg'=>'缺少必要參數(shù):token']);$userinfo = checkToken($token);if($userinfo['code']!=200) return json(['code'=>202,'msg'=>'token驗(yàn)證失敗']);return json($userinfo); }}(二)請(qǐng)求接口測(cè)試

1.請(qǐng)求index接口,并復(fù)制返回的token值

2.將操作1中復(fù)制的token值復(fù)制到請(qǐng)求頭中的token去

基本的使用就成功啦,接下來(lái)使用中間件來(lái)模擬登陸的情況。

四、在ThinkPHP6中使用JWT+中間件生成驗(yàn)證Token(一)代碼文件

common.php-同上

app\index\controller中:index.php

<?phpnamespace app\index\controller;use app\BaseController;use think\facade\Db;use think\response\Json;class Index extends BaseController{ /** * 模擬登陸接口的成功情況,將用戶關(guān)鍵信息加密到token再返回給前端 * @return Json */ public function wxLogin():Json {$userinfo = ['id'=>1,'openid'=>'123456789'];$token = ['token'=>signToken($userinfo)];return json(['code'=>200,'msg'=>'success to login','data'=>$token]); } /** * 模擬需要驗(yàn)證token的方法做點(diǎn)事 * @return Json */ public function toDo() :Json {$user = request()->userInfo;//$userinfo = Db::name('user')// ->where('id',$user['id']) //可以使用這些信息搜索某些關(guān)鍵信息// ->findOrEmpty();return json(['code'=>200,'msg'=>'u can use the data to search some information or do something','data'=>$user]); }}

app\middleware中:CheckToken.php(中間件,驗(yàn)證token)

<?phpnamespace app\middleware;use think\Exception;use \think\facade\Request;class CheckToken{ public function handle($request, \Closure $next) {try { $token = Request::header()['token']??false; if(!$token)throw new Exception('Without Token',201); $userinfo = checkToken($token); if($userinfo['code'] != 200)throw new Exception('Token checked error',202);// $userinfo['data']['token'] = $token; $request->userInfo = $userinfo['data'];}catch (Exception $err){ return json(['code'=>$err->getCode(),'msg'=>$err->getMessage()]);}return $next($request); }}

app\index\route中:app.php(路由,綁定中間件驗(yàn)證)

<?phpuse think\facade\Route;Route::group(function (){ //需要經(jīng)過(guò)checkToken驗(yàn)證的接口 Route::post('toDo','/toDo');})->prefix(\app\index\controller\Index::class)->middleware(app\middleware\CheckToken::class);Route::group(function(){ //單純的路由~ Route::post('wxLogin','/wxLogin');})->prefix(\app\index\controller\Index::class);(二)請(qǐng)求接口測(cè)試

1.請(qǐng)求登陸接口

2.帶著登陸接口返回的token去請(qǐng)求需要驗(yàn)證token的接口 (對(duì)&錯(cuò)都試一遍)

true:(正確的嘗試)

false:(將token的第一個(gè)字符去掉)

五、總結(jié)

JWT的詳細(xì)介紹在文章開(kāi)頭的鏈接中啥都有,本文主要記錄JWT入門(mén)實(shí)戰(zhàn)的使用,知識(shí)方面互聯(lián)網(wǎng)本就存在那么多好文章~我就不多描述了。

本篇文章就到此為止辣,簡(jiǎn)單點(diǎn)說(shuō)就是用個(gè)擴(kuò)展,為啥要記錄,因?yàn)楹芏嗟奈恼路乓恍€代碼(用不得,到處報(bào)錯(cuò)),想找一篇好的文章學(xué)習(xí)也開(kāi)始變的困難起來(lái),世風(fēng)日下啊~寫(xiě)的比較匆忙,如果有錯(cuò)誤、問(wèn)題,歡迎指正提問(wèn)~

此外,JWT進(jìn)行token驗(yàn)證應(yīng)用非常廣泛,筆者測(cè)試過(guò)的node.js、Go語(yǔ)言都有JWT驗(yàn)證的相關(guān)應(yīng)用。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 91久久精品青青草原伊人 | 丝袜亚洲综合 | 国产欧美视频在线观看 | 青草视频在线 | 一级黄色录像毛片 | 国产精品二区页在线播放 | 欧洲男女啪啪免费观看 | 欧美日韩免费看 | 亚洲一级毛片欧美一级说乱 | 久久91精品国产一区二区 | xvideos国产 | 18美女福利视频网站免费观看 | 久久精品国产精品亚洲精品 | 日韩欧美一区二区三区 | 国产精品视频全国免费观看 | 打美眉屁股v7.3| 国产又色又粗又黄又爽免费 | 国产成人精品免费视频 | 亚洲精品国产福利在线观看 | 国产乱子精品免费视观看片 | 欧美特黄一区二区三区 | 91av在线国产 | 啪啪免费网站入口链接 | 欧美性生大片免费观看 | 福利在线一区 | 久久精品精品 | 91久久香蕉青青草原娱乐 | 日韩免费高清一级毛片久久 | 爱爱视频免费 | 欧美成人影院在线观看三级 | 欧美日韩在线国产 | 久久久综合久久 | 欧美性色黄大片a级毛片视频 | 在线观看精品自拍视频 | 亚洲欧美一二三区 | 日韩在线视屏 | 亚洲精品黄色 | 国产欧美一区二区三区久久 | 国产一区二区三区不卡免费观看 | 欧美在线观看日韩欧美在线观看 | 国产一级毛片视频在线! |