Python 无法解码 PHP 创建的 JWT 代码

Posted

技术标签:

【中文标题】Python 无法解码 PHP 创建的 JWT 代码【英文标题】:Python can't decode PHP created JWT code 【发布时间】:2018-05-26 00:35:12 【问题描述】:

我正在使用 python 客户端和 php 服务器以及 JWT 编码消息进行通信。我在 PHP 中创建了一条消息,但 Python JWT 编码器说这不是 JSON 对象。对于 PHP JWT,我使用 Firebase JWT 编码器(但其他 JWT 编码器 jwt_helper.php 是相同的,我在网上找到的)。 PHP版本:PHP7,python:2.7

这是php中的代码:

$obj = new stdClass();
$obj->result = 'OK';
$txt = json_encode($obj);

$secret_key = 'secret_key';

$encoded = Firebase\JWT\JWT::encode($txt, $secret_key);
$decoded = Firebase\JWT\JWT::decode($encoded, $secret_key, array('HS256'));

echo $decoded;
echo '<br />';
echo $encoded;
?>

输出是: “结果”:“确定” eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.IntcInJlc3VsdFwiOlwiT0tcIn0i.dI4aO1UsXblWGCiLZbqQylRf8x6tgSWbeqYAw6rl5Sc

现在,我正在尝试用 Python 对其进行解码:

jwt.decode('eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.IntcInJlc3VsdFwiOlwiT0tcIn0i.dI4aO1UsXblWGCiLZbqQylRf8x6tgSWbeqYAw6rl5Sc','secret_key')

Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/home/myuser/.local/lib/python2.7/site-packages/jwt/api_jwt.py", line 86, in decode
    raise DecodeError('Invalid payload string: must be a json object')
jwt.exceptions.DecodeError: Invalid payload string: must be a json object

你能帮帮我吗?也许我使用了错误的包或错误的字符编码?我尝试在 PHP 文件中准确添加 JSON 输出,例如 $txt="'result':'OK'";,但同样的错误。 另一种方法很好,如果我在 Python 中创建一个 JWT 编码的字符串,我可以在 PHP 中对其进行解码。

感谢和问候, 内核

【问题讨论】:

【参考方案1】:

您在 PHP 中生成的令牌是错误的。 在 https://jwt.io/ 上检查您的令牌

它会显示:

有效载荷数据:

"\"结果\":\"OK\""

额外的引号是问题所在。

改用以下代码生成您的令牌:

$payload = array(
          "result" => "ok"
       );

$encoded  = Firebase\JWT\JWT::encode($payload, $secret_key, "HS256");

您可以根据需要向数组中添加其他值。

【讨论】:

以上是关于Python 无法解码 PHP 创建的 JWT 代码的主要内容,如果未能解决你的问题,请参考以下文章

PHP JWT:: **解码** 过期令牌

无法解码 Firebase JWT

在 Python 中使用来自 Gravitee 的公钥解码 JWT 令牌时出现问题

从 Google 解码 JWT 字符串失败 [php]

PHP Slim 解码 JWT 令牌

尝试解码 Jwt 令牌时出现“尝试解码 Jwt 时发生错误:无法检索远程 JWK 集:”错误