hyperf - 项目 用于验证 jwt 令牌并确保身份验证过程中的真实性和完整性的简单系统。 创建 - 项目 composer create-project hyperf/hyp" />
登录
首页 >  文章 >  php教程

PHP HyperF -> Firebase JWT

来源:dev.to

时间:2025-01-06 09:48:35 486浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习文章的朋友们,也希望在阅读本文《PHP HyperF -> Firebase JWT》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新文章相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

PHP HyperF -> Firebase JWT Firebase JWT" />

hyperf - 项目

用于验证 jwt 令牌并确保身份验证过程中的真实性和完整性的简单系统。

创建 - 项目

composer create-project hyperf/hyperf-skeleton "project"

安装-观察者

composer require hyperf/watcher --dev

安装 - firebase jwt

composer require firebase/php-jwt

服务器 - 启动

cd project ;
php bin/hyperf.php server:watch ;

hyperf-app

app-环境

jwt_key="***"

路径:/project/.env

app-路由器

router::addroute(['get', 'post'], '/generate', 'app\controller\controllerjwt@generate');
router::addroute(['get', 'post'], '/decode', 'app\controller\controllerjwt@decode');

路径:/project/config/routes.php

app-控制器

namespace app\controller;

use hyperf\di\annotation\inject;
use hyperf\httpserver\contract\requestinterface;
use hyperf\httpserver\contract\responseinterface;

use function hyperf\support\env;

use ramsey\uuid\uuid;

use firebase\jwt\jwt;
use firebase\jwt\key;

class controllerjwt
{
    #[inject]
    protected requestinterface $request;

    #[inject]
    protected responseinterface $response;

    protected $jwt_key;

    public function __construct()
    {
        $this->jwt_key=env('jwt_key', '***');
    }

    public function generate()
    {
        $payload=[
            'uuid'=>uuid::uuid4()->tostring(),
            'token'=>sha1(str_shuffle('0123456789abcdefghijklmnopqrstuvwxyz')),
        ];
        $token=jwt::encode($payload, $this->jwt_key, 'hs256');
        return [
            'payload'=>$payload,
            'token'=>$token,
        ];
    }

    public function decode()
    {
        $token=$this->request->getheader('authorization')[0] ?? '';
        $token=str_replace('bearer ', '', $token);
        try {
            $decode=jwt::decode($token, new key($this->jwt_key, 'hs256'));
        } catch (\exception $e){
            return $this->response->withstatus(401)->json(['token'=>'invalid']);
        }
        return [
            'token'=>$token,
            'decode'=>$decode,
        ];
    }

}

路径:/project/app/controller/controllerjwt.php

执行

get - 生成令牌

curl "http://127.0.0.1:9501/generate"

response:
{
    "payload": {
        "uuid": "...0123",
        "token": "***"
    },
    "token": "***"
}

get - 解码令牌

curl "http://127.0.0.1:9501/decode" -H "Authorization: Bearer %token%"

Response:
{
    "token": "***",
    "decode": {
        "uuid": "...0123",
        "token": "***"
    }
}

https://github.com/thiagoeti/php-hyperf-firebase-jwt

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>