env('TOKEN.iss'),//签发作者"aud"=>env('TOKEN.aud'),"iat"=>$time,"nbf"=>$time,"exp"=>$expire);returnjson(JWTUtil::enco"/> env('TOKEN.iss'),//签发作者"aud"=>env('TOKEN.aud'),"iat"="/>

ThinkPHP6集成JWT方法以及生成和取出销毁详解

2023-06-24 5页 doc 163KB 40阅读

用户头像 个人认证

is_856463

暂无简介

举报
ThinkPHP6集成JWT方法以及生成和取出销毁详解     ThinkPHP6集成JWT方法以及生成和取出销毁详解                  1.引入php-jwt包composerrequirefirebase/php-jwt2.代码控制器文件:app\business\Jwt.php"$user_id",//签发组织"iss"=>env('TOKEN.iss'),//签发作者"aud"=>env('TOKEN.aud'),"iat"=>$time,"nbf"=>$time,"exp"=>$expire);returnjson(JWTUtil::encode($to...
ThinkPHP6集成JWT方法以及生成和取出销毁详解
     ThinkPHP6集成JWT方法以及生成和取出销毁详解                  1.引入php-jwt包composerrequirefirebase/php-jwt2.代码控制器文件:app\business\Jwt.php"$user_id",//签发组织"iss"=>env('TOKEN.iss'),//签发作者"aud"=>env('TOKEN.aud'),"iat"=>$time,"nbf"=>$time,"exp"=>$expire);returnjson(JWTUtil::encode($token,$key));}/***验证token*@return\think\response\Json*/publicstaticfunctionverifyjwt($jwt){//查看token是否过期(在退出登录的逻辑里会手动让其过期)if(!empty(cache('delete_token'))&&in_array($jwt,cache("delete_token"))){thrownewExpiredException("token过期","400");}//jwt的签发密钥,验证token的时候需要用到$key=md5(env('TOKEN.key'));try{$jwtAuth=json_encode(JWTUtil::decode($jwt,$key,array("HS256")));$authInfo=json_decode($jwtAuth,true);if(!$authInfo['user_id']){thrownewException('用户ID不存在','500');}//验签成功返回returnjson($authInfo);}catch(ExpiredException$e){thrownewException('token过期','500');}catch(\Exception$e){thrownewException($e->getMessage(),'500');}}//从请求信息中获取token令牌publicstaticfunctiongetRequestToken(){if(empty($_SERVER['HTTP_AUTHORIZATION'])){returnfalse;}$header=$_SERVER['HTTP_AUTHORIZATION'];$method='bearer';//去除token中可能存在的bearer标识returntrim(str_ireplace($method,'',$header));}}3.修改public/.htaccess文件,通过apache重写,处理HTTP请求中的Authorization字段(不处理,php中接收不到HTTP_AUTHORAZATION字段信息)RewriteCond%{HTTP:Authorization}^(.+)$RewriteRule.*-[E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]4.路由:app\api\route\api.phpgetData();6.前端:取出、销毁publicfunctionlogin(){//取出Token值(寄托在header)//清空token将需清空的token存入缓存,再次使用时,会读取缓存进行判断$token=JWT::getRequestToken();//查看缓存中是否存在delete_token这个键$delete_token=cache('delete_token')?:[];//将这个token值放入delete_token数组中$delete_token[]=$token;//将数组塞回缓存中cache('delete_token',$delete_token,86400);//销毁成功returnsuccess('销毁成功');}7.验证是否成功//取出token$token=JWT::getRequestToken();try{//校验token$data=JWT::verifyjwt($token);}catch(\Exception$exception){returnfail($exception->getMessage());}dd($data);8.效果如图所示 -完-
/
本文档为【ThinkPHP6集成JWT方法以及生成和取出销毁详解】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。

历史搜索

    清空历史搜索