php自定义token类并将生成的token放在http请求头的Authorization中的代码

不言
发布: 2018-08-15 16:42:30
原创
8563人浏览过

本篇文章给大家带来的内容是关于php自定义token类并将生成的token放在http请求头的Authorization中的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

今天在使用laravel写东西的时候,需要与前端交互,看了jwt(json web token),于是自己想试着写一个简单的token类,token中存储了成员id和成员的权限,与前端交互时,将生成的token放在http请求头的authorization中,整理如下:

<?php
namespace App\Http\Controllers\Auth;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
class TokenController extends Controller{
    /**
     * header
     * @var array
     */
    private static $header = [        
    "type" => "token",        
    "alg"  => "HS256"
    ];    /**
     * create payload
     * @param $memberId
     * @param $permission
     * @return array
     */
    private static function payload($memberId, $permission)
    {
        return [            
        "iss"       => "http://api.creatshare.com",            
        "iat"       => $_SERVER['REQUEST_TIME'],           
         "exp"       => $_SERVER['REQUEST_TIME'] + 7200,            
         "GivenName" => "CreatShare",            
         "memberId"  => $memberId,            
         "permission"=> $permission
        ];
    }    /**
     * encode data
     * @param $data
     * @return string
     */
    private static function encode($data)
    {
        return base64_encode(json_encode($data));
    }    /**
     * generate a signature
     * @param $header
     * @param $payload
     * @param string $secret
     * @return string
     */
    private static function signature($header, $payload, $secret = 'secret')
    {
        return hash_hmac('sha256', $header.$payload, $secret);
    }    /**
     * generate a token
     * @param $memberId
     * @param $permission
     * @return string
     */
    public static function createToken($memberId, $permission)
    {
        $header = self::encode(self::$header);        
        $payload = self::encode(self::payload($memberId, $permission));        
        $signature = self::signature($header, $payload);        
        return $header . '.' .$payload . '.' . $signature;
    }    /**
     * check a token
     * @param $jwt
     * @param string $key
     * @return array|string
     */
    public static function checkToken($jwt, $key = 'secret')
    {
        $token = explode('.', $jwt);        
        if (count($token) != 3)           
         return 'token invalid';        
         list($header64, $payload64, $sign) = $token;        
         if (self::signature($header64 , $payload64) !== $sign)            
         return 'token invalid';        
         $header = json_decode(base64_decode($header64), JSON_OBJECT_AS_ARRAY);        
         $payload = json_decode(base64_decode($payload64), JSON_OBJECT_AS_ARRAY);        
         if ($header['type'] != 'token' || $header['alg'] != 'HS256')            
         return 'token invalid';        
         if ($payload['iss'] != 'http://api.creatshare.com' || $payload['GivenName'] != 'CreatShare')            
         return 'token invalid';        
         if (isset($payload['exp']) && $payload['exp'] < time())            
         return 'timeout';        
         return [           
          'memberId' => $payload['memberId'],            
         'permission' =>$payload['permission']
        ];
    }    /**
     * get a token
     * @return null
     */
    public static function getToken()
    {
        $token = null;        
        if (isset($_SERVER['HTTP_AUTHORIZATION']))            
        $token = $_SERVER['HTTP_AUTHORIZATION'];        
        return $token;
    }
}
登录后复制
$token = Token::createToken($member_id, $member_permission); //创建一个
token$token = Token::getToken();    //从http请求头获取
token$result = Token::checkToken(); //解析token
登录后复制

相关推荐:

php xml操作类(自定义)

PHP实现可自定义样式的分页类,php自定义样式分页

通义灵码
通义灵码

阿里云出品的一款基于通义大模型的智能编码辅助工具,提供代码智能生成、研发智能问答能力

通义灵码 31
查看详情 通义灵码

php中自定义类文件自动加载

立即学习PHP免费学习笔记(深入)”;

以上就是php自定义token类并将生成的token放在http请求头的Authorization中的代码的详细内容,更多请关注php中文网其它相关文章!

相关标签:
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号