thinkphp使用说明(thinkphp框架使用JWTtoken的方法详解)
类别:编程学习 浏览量:309
时间:2021-10-15 00:53:32 thinkphp使用说明
thinkphp框架使用JWTtoken的方法详解本文实例讲述了thinkphp框架使用JWTtoken的方法。分享给大家供大家参考,具体如下:
简介
一:JWT介绍:全称JSON Web Token,基于JSON的开放标准((RFC 7519) ,以token的方式代替传统的Cookie-Session模式,用于各服务器、客户端传递信息签名验证。
二:JWT优点:
1:服务端不需要保存传统会话信息,没有跨域传输问题,减小服务器开销。
2:jwt构成简单,占用很少的字节,便于传输。
3:json格式通用,不同语言之间都可以使用。
三:JWT组成
1:jwt由三部分组成:
头部(header)
载荷(payload) 包含一些定义信息和自定义信息
签证(signature)
2:具体构成:
header:
|
{ "typ" : "JWT" , //声明类型为jwt "alg" : "HS256" //声明签名算法为SHA256 } |
载荷(payload)
|
{ "iss" : "http://www.helloweba.net" , "aud" : "http://www.helloweba.net" , "iat" : 1525317601, "nbf" : 1525318201, "exp" : 1525318201, "data" : { "userid" : 1, "username" : "李小龙" } } |
载荷包括两部分:标准声明和其他声明。
标准声明:JWT标准规定的声明,但不是必须填写的;
标准声明字段:
接收该JWT的一方
iss: jwt签发者
sub: jwt所面向的用户
aud: 接收jwt的一方
exp: jwt的过期时间,过期时间必须要大于签发时间
nbf: 定义在什么时间之前,某个时间点后才能访问
iat: jwt的签发时间
jti: jwt的唯一身份标识,主要用来作为一次性token。
下载
|
composer require firebase /php-jwt |
extend 下创建token类
|
namespace Token; use think\Controller; use think\facade\Request; use Firebase\JWT\JWT; /**token类 * Class Token * @package app\api\Controller */ class Token { /** * 创建 token * @param array $data 必填 自定义参数数组 * @param integer $exp_time 必填 token过期时间 单位:秒 例子:7200=2小时 * @param string $scopes 选填 token标识,请求接口的token * @return string */ private $TokenKey = "123456" ; public function createToken( $data = "" , $exp_time =0, $scopes = "" ){ //JWT标准规定的声明,但不是必须填写的; //iss: jwt签发者 //sub: jwt所面向的用户 //aud: 接收jwt的一方 //exp: jwt的过期时间,过期时间必须要大于签发时间 //nbf: 定义在什么时间之前,某个时间点后才能访问 //iat: jwt的签发时间 //jti: jwt的唯一身份标识,主要用来作为一次性token。 //公用信息 try { $key = $this ->TokenKey; $time = time(); //当前时间 //$token['iss']=''; //签发者 可选 //$token['aud']=''; //接收该JWT的一方,可选 $token [ 'iat' ]= $time ; //签发时间 $token [ 'nbf' ]= $time ; //(Not Before):某个时间点后才能访问,比如设置time+30,表示当前时间30秒后才能使用 if ( $scopes ){ $token [ 'scopes' ]= $scopes ; //token标识,请求接口的token } if (! $exp_time ){ $exp_time =7200; //默认=2小时过期 } $token [ 'exp' ]= $time + $exp_time ; //token过期时间,这里设置2个小时 if ( $data ){ $token [ 'data' ]= $data ; //自定义参数 } $json = JWT::encode( $token , $key ); $returndata [ 'status' ]= "200" ; // $returndata [ 'msg' ]= 'success' ; $returndata [ 'token' ]= $json ; //返回的数据 return $returndata ; //返回信息 } catch (\Firebase\JWT\ExpiredException $e ){ //签名不正确 $returndata [ 'status' ]= "104" ; //101=签名不正确 $returndata [ 'msg' ]= $e ->getMessage(); $returndata [ 'data' ]= "" ; //返回的数据 return $returndata ; //返回信息 } catch (\Exception $e ) { //其他错误 $returndata [ 'status' ]= "199" ; //199=签名不正确 $returndata [ 'msg' ]= $e ->getMessage(); $returndata [ 'data' ]= "" ; //返回的数据 return $returndata ; //返回信息 } } /** * 验证token是否有效,默认验证exp,nbf,iat时间 * @param string $jwt 需要验证的token * @return string $msg 返回消息 */ public function checkToken( $jwt ){ $key = $this ->TokenKey; try { JWT:: $leeway = 60; //当前时间减去60,把时间留点余地 $decoded = JWT::decode( $jwt , $key , [ 'HS256' ]); //HS256方式,这里要和签发的时候对应 $arr = ( array ) $decoded ; $returndata [ 'status' ]= "200" ; //200=成功 $returndata [ 'msg' ]= "success" ; // $returndata [ 'data' ]= $arr ; //返回的数据 return $returndata ; //返回信息 } catch (\Firebase\JWT\SignatureInvalidException $e ) { //签名不正确 $returndata [ 'status' ]= "101" ; //101=签名不正确 $returndata [ 'msg' ]= $e ->getMessage(); $returndata [ 'data' ]= "" ; //返回的数据 //return json_encode($returndata); //返回信息 //exit(json_encode($returndata)); sendResponse( $returndata ,401, 'Unauthorized' ); } catch (\Firebase\JWT\BeforeValidException $e ) { // 签名在某个时间点之后才能用 $returndata [ 'status' ]= "102" ; $returndata [ 'msg' ]= $e ->getMessage(); $returndata [ 'data' ]= "" ; //返回的数据 sendResponse( $returndata ,401, 'Unauthorized' ); } catch (\Firebase\JWT\ExpiredException $e ) { // token过期 $returndata [ 'status' ]= "103" ; //103=签名不正确 $returndata [ 'msg' ]= $e ->getMessage(); $returndata [ 'data' ]= "" ; //返回的数据 sendResponse( $returndata ,401, 'Unauthorized' ); } catch (\Exception $e ) { //其他错误 $returndata [ 'status' ]= "199" ; //199=签名不正确 $returndata [ 'msg' ]= $e ->getMessage(); $returndata [ 'data' ]= "" ; //返回的数据 sendResponse( $returndata ,401, 'Unauthorized' ); } //Firebase定义了多个 throw new,我们可以捕获多个catch来定义问题,catch加入自己的业务,比如token过期可以用当前Token刷新一个新Token } |
签发
|
$jwtToken = new Token(); $tokenData = array ( 'openid' => $user ->getId(), 'uniacid' => $_W [ 'uniacid' ], ); $token = $jwtToken ->createToken( $tokenData ) |
验证
|
if ( empty ( $_SERVER [ 'HTTP_AUTHORIZATION' ])) { $res [ 'status' ]= "201" ; $res [ 'msg' ]= "no token" ; $res [ 'data' ]= "" ; //返回的数据 sendResponse( $res ,401, 'Unauthorized' ); } $token = $_SERVER [ 'HTTP_AUTHORIZATION' ]; $jwtToken = new Token(); $checkToken = $jwtToken ->checkToken( $token ); $data = ( array ) $checkToken [ 'data' ][ 'data' ]; |
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/flysnownet/article/details/90260826
您可能感兴趣
- thinkphp权限认证怎么用(ThinkPHP框架结合Ajax实现用户名校验功能示例)
- thinkphp5怎么设置默认返回(thinkphp5.1框架实现格式化mysql时间戳为日期的方式小结)
- 如何用thinkphp框架来写一个网站(php tpl模板引擎定义与使用示例)
- thinkphp5.1插件实现(Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例)
- thinkphp框架切换数据库(ThinkPHP3.2.3框架实现执行原生SQL语句的方法示例)
- thinkphp框架多文件上传完整代码(Thinkphp5 自定义上传文件名的实现方法)
- thinkphp源码上传(ThinkPHP框架实现FTP图片上传功能示例)
- thinkphp怎么整合微信支付(ThinkPHP框架实现的微信支付接口开发完整示例)
- thinkphp怎么输出二维值(thinkphp 表名 大小写 窍门)
- thinkphp3.2.3 接口开发(ThinkPHP3.2.3框架Memcache缓存使用方法实例总结)
- thinkphp框架案例(thinkphp5.1框架容器与依赖注入实例分析)
- thinkphpmodel使用教程(Thinkphp5.0 框架Model模型简单用法分析)
- thinkphp快速入门手册(从ThinkPHP3.2.3过渡到ThinkPHP5.0学习笔记图文详解)
- thinkphp分页效果怎样(thinkphp5+layui实现的分页样式示例)
- thinkphp兼容dedecms(DedeCMS Error:Tag disabled:"php"的解决办法)
- thinkphp5.1请求流程(ThinkPHP5.0框架使用build 自动生成模块操作示例)
- 中国有几个名族(中国有几个民族没列入56个民族)
- 数学语文题目(语文的数学题)
- 香蕉(香蕉三种人不宜吃)
- 没钱可以快乐吗(没钱也能快乐吗)
- 快乐是什么(快乐就是)
- 东南亚有哪个国家(东南亚有哪个国家最发达)
热门推荐
- mysql数据库调优技术大全(Mysql数据库性能优化三分表、增量备份、还原)
- mysql8.0.12安装教程图解(mysql 8.0.22 zip压缩包版免安装下载、安装配置步骤详解)
- mysql索引为什么是b+树(mysql 使用B+树索引有哪些优势)
- centos中docker安装部署(三分钟完成 ubuntu16.04初始化,Java,maven,docker环境的部署问题)
- ftp两种传输协议有什么区别(FTP与SFTP的区别 知多少)
- php有几种模式(php 策略模式原理与应用深入理解)
- mybatis执行sql源码解析(mybatis调用sqlserver存储过程返回结果集的方法)
- js函数对象
- laravel-admin代码执行流程(解决laravel-admin 自己新建页面里 js 需要刷新一次的问题)
- dedecms标签调用详解(Dedecms待审核文章在列表页显示的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9