php对接firebase验证jwt的令牌ID客户端id_token

firebase

谷歌的一个开源的数据平台,我们可以自定义我们的信息存储在平台上。最近因为游戏需要对接谷歌,里面获取用户登录信息需要对接到firebase。文档看的迷迷糊糊。
在这里插入图片描述

因为跟我之前没接触过海外项目,但是对接的前端之前对接过,他说是前端获取到一个id_token,然后我服务端
解析一下就可以了,网上查了半天,找到的资料还是比较少,最后综合一下搞出来了,直接上代码:

		$jwt = input('get.id_token/s','');
        $tokens = explode('.', $jwt);
        $headerString = base64_decode($tokens[0]);
        if(!$headerString) {
            return_json('',201,'ID token error!');
        }
        $header = json_decode($headerString, true);
        $publicKey = $this->getPublicKeyByKid($header['kid']);

        $payload = JWT::decode($jwt, new Key($publicKey, 'RS256'));

        $unionid = $payload->user_id;//唯一标识
        $nick_name = $payload->name;
        $head_img = $payload->picture;
		......下面就是自己的业务逻辑了
public function getPublicKeyByKid($kid){
        $redis = new Redis();
        $publicKeyCachePrefix = "public_key_";
        $cacheKey = $publicKeyCachePrefix.$kid;
        $publicKey = $redis->get($cacheKey);
        if(empty($publicKey)) {
            $httpClient = new HttpClient("https://www.googleapis.com/robot/v1/metadata/x509/securetoken@system.gserviceaccount.com", 'GET');
            $httpClient->exec();
            $responseBody = $httpClient->getResponseBody();
            $publicKeyArray = json_decode($responseBody, true);
            foreach ($publicKeyArray as $k => $v) {
                $redis->set($publicKeyCachePrefix.$k, $v, 10000);
                if($k == $kid) {
                    $publicKey = $v;
                }
            }
        }
        return $publicKey;
    }
这里比较关键的一点就是使用jwt进行令牌验证的公钥和私钥的获取。最开始以为是合作方提供,后面找遍了各种
文档也没有发现公钥和私钥,客户端也不知道自己从SDK获取到的令牌是用什么方式加密的,因此各种尝试,最终
在文档中找到了一个固定网址获取到公https://www.googleapis.com/robot/v1/metadata/x509/secur
etoken@system.gserviceaccount.com

在这里插入图片描述

正常解析成功之后,就会获取到用户的name,picture,email这些了,user_id是唯一标识,接下来就是根据自
己业务来写下面的了,好啦,此文仅是个人记录工作,希望能对你有帮助。
  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大力水手z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值