【问题标题】:Firebase JWT library can't verify Python JWT tokenFirebase JWT 库无法验证 Python JWT 令牌
【发布时间】:2017-07-31 17:03:33
【问题描述】:

所以我有一个 python 客户端和一个 PHP 后端。 python客户端使用pyjwt,php服务器使用Firebase JWT

在 php 中编码和解码令牌时,一切正常。但是当我从 python 编码令牌并使用 php 解码它们时,Firebase 库返回一个错误:

Firebase\JWT\SignatureInvalidException Object
(
    [message:protected] => Signature verification failed
    [string:Exception:private] => 
    [code:protected] => 0
    [file:protected] => /var/www/vendor/firebase/php-jwt/src/JWT.php
    [line:protected] => 110
    ...

编码python代码如下

import jwt
...
payload = {'sub': self.client.id, 'exp': (datetime.now() + timedelta(days=1)).timestamp()}
context['token'] = jwt.encode(payload, os.environ['JWT_KEY'], algorithm='HS256')

PHP代码如下

$key = getenv("JWT_KEY");
return (array) \Firebase\JWT\JWT::decode($token, $key, array('HS256'));

【问题讨论】:

    标签: php python firebase token jwt


    【解决方案1】:

    好的,我发现了问题。问题是各方使用的密钥。尝试被 PHP 读取时,密钥出现问题,这就是它创建不同令牌的原因。库还可以,它们之间可以毫无问题地相互通信。

    【讨论】:

      猜你喜欢
      • 2019-07-29
      • 2018-06-12
      • 2017-04-05
      • 2019-06-23
      • 2021-09-04
      • 2017-07-27
      • 2019-10-20
      • 2016-01-17
      • 2022-01-18
      相关资源
      最近更新 更多