专业IT网络知识平台,分享IT百科知识、生活百科知识解答!

易企推科技
易企推科技

JWT是什么?对JWT的简单认识

来源:小易整编  作者:小易  发布时间:2024-03-15 07:56
摘要:本篇文章给大家带来的内容是关于jwt是什么?对jwt的简单认识,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。一直没有好好看过jwt,直到前两天要做web验证,朋友给我推荐了jwt。才发现jwt已经被大家广泛的应用了。看来我...

本篇文章给大家带来的内容是关于jwt是什么?对jwt的简单认识,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

JWT是什么?对JWT的简单认识

一直没有好好看过jwt,直到前两天要做web验证,朋友给我推荐了jwt。才发现jwt已经被大家广泛的应用了。看来我有点out了。哈哈,趁着这个世界来好好看看这个。

JWT(JSON Web Token), 顾名思义就是可以在Web上传输的token,这种token是用JSON格式进行format的。它是一个开源标准(RFC 7519),定义了一个紧凑的自包含的方式在不同实体之间安全的用JSON格式传输信息。

由于现在很多项目都是前后端分离,restful api模式。所以传统的session模式就没有办法满足认证需求,这个时候jwt的作用就来了。可以说 restful api认证是jwt的一个很好的应用场景。

下面是一个很小的demo

'dadsa-12312-vsd1s1-fsds',    'account'=>'daisc',    'password'=>'123456'];$redis = redis();$action  =  $_GET['action'];switch ($action){    case 'login':        login();        break;    case 'info':        info();        break;}//登陆,写入验证tokenfunction 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',//签发者            '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']connect('127.0.0.1');    return $redis;}
登录后复制

这个dmeo里面用jwt做了一个简单的认证。 其中用到了一个php-jwt的加密包github/firebase/php-jwt

其中KEY为定义的私钥也就是jwt里面的 sign部分,这个一定要保存好。而header部分php-jwt包里面已经帮我们完成了,加密代码如下

    */    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);    }
登录后复制

可以看出默认的加密的方式是HS256。这也是说jwt安全的原因。现阶段HS256加密还是很安全的。这个包里面也支持证书加密。

加密解密的过程这个包已经帮我们完成了。所以我们只需要定义jwt中的 poyload部分就可以了。也就是demo里面的token部分。加密成功会得到一个加密的Jwt字符串,下次前端在请求api的时候需要携带这个jwt字符串作为认证。在header头里面增加Authorization。在服务端验证的时候回通过取得这个值来验证回话的有效。

下面是poyload的一些常用配置

 $token   = [            #非必须。issuer 请求实体,可以是发起请求的用户的信息,也可是jwt的签发者。            "iss"       => "http://example.org",            #非必须。issued at。 token创建时间,unix时间戳格式            "iat"       => $_SERVER['REQUEST_TIME'],            #非必须。expire 指定token的生命周期。unix时间戳格式            "exp"       => $_SERVER['REQUEST_TIME'] + 7200,            #非必须。接收该JWT的一方。            "aud"       => "http://example",            #非必须。该JWT所面向的用户            "sub"       => "jrocket@example",            # 非必须。not before。如果当前时间在nbf里的时间之前,则Token不被接受;一般都会留一些余地,比如几分钟。            "nbf"       => 1357000000,            # 非必须。JWT ID。针对当前token的唯一标识            "jti"       => '222we',            # 自定义字段            "GivenName" => "Jonny",            # 自定义字段            "name"   => "Rocket",            # 自定义字段            "Email"     => "jrocket@example",                 ];
登录后复制

里面包含的配置可以自由配置,也可以自己添加一些其他的。这些都是网上大家常用的,可以说是一种约定吧。

以上就是JWT是什么?对JWT的简单认识的详细内容,更多请关注易企推科技其它相关文章!


本文地址:网络知识频道 https://www.hkm168.com/jiqiao/1148446.html,易企推百科一个免费的知识分享平台,本站部分文章来网络分享,本着互联网分享的精神,如有涉及到您的权益,请联系我们删除,谢谢!


网络知识
小编:小易整编
相关文章相关阅读
  • 某台微机安装的是64位操作系统中,64位指的是什么

    某台微机安装的是64位操作系统中,64位指的是什么

    某台微机安装的是64位操作系统中,64位指的是cpu的字长,即cpu每次能处理64位二进制数据。字长是cpu的主要技术指标之一,指的是cpu一次能并行处理的二进制位数,字长总是8的整数倍,通常pc机的字长为32位,64位。本教程操作环境:w...

  • c语言是什么意思

    c语言是什么意思

    一:c语言是什么意思C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言是仅产生少量的机器语言,以及不需要任何运行环境支持便能运行的高效率程序设计语言。尽管C语言提供了许多低...

  • skype是什么软件

    skype是什么软件

    skype是一种简单的免费软件,使您能够在数分钟之内在世界上的任何角落拨打免费电话,它使用全新的p2p【对等】技术将您与其他skype用户相连接。Skype是一种简单的免费软件,使您能够在数分钟之内在世界上的任何角落拨打免费电话。Sky...

  • 计算机的三类总线分别是什么?

    计算机的三类总线分别是什么?

    计算机的三类总线分别是:控制总线、地址总线和数据总线。控制总线用于将微处理器控制单元的信号,传送到周边设备;地址总线用来指定在ram之中储存的数据的地址;数据总线用于在cpu与ram之间来回传送需要处理或是需要储存的数据。总线(Bus)是计...

  • 2k屏幕是什么意思

    2k屏幕是什么意思

    2k屏幕是指分辨率能够达到2560*1440的屏幕。2k是一个通用术语,指屏幕或者内容的水平分辨率达约2000像素的分辨率等级;又因“16:9”的比例是高清晰度视频规格的国际标准,所以2k分辨率在视频制作、显示屏等领域常见格式为2560*1...

  • mysql中的不等于符号是什么

    mysql中的不等于符号是什么

    mysql中的不等于符号有两种:“!=”和“”;它们都可用于判断数字、字符串、表达式是否不相等。对于“!=”和“”,如果两侧操作数不相等,返回值为1,否则返回值为0;如果两侧操作数有一个是null,那么返回值也是null。本教程操作环境:w...

  • ipad a1822是什么型号

    ipad a1822是什么型号

    ipada1822是苹果ipad第5代的型号;ipad第5代是苹果公司于2017年03月21日在美国加利福尼亚州发布的平板电脑;该机型采用铝镁合金材质一体成型结构;前端外框为白色或黑色;有银色、金色和深空灰色3种外观颜色。本教程操作环境:...

  • html中浮动是什么

    html中浮动是什么

    在html中,浮动就是让元素可以向左或向右移动,直到它的外边距碰到其父级的内边距或者是上一个元素的外边距,只需要给元素设置“float:left|right|none|inherit”样式即可。本教程操作环境:windows7系统、CSS3...

  • 周排行
  • 月排行
  • 年排行

精彩推荐