[英]Firebase JWT library can't verify Python JWT token
所以我在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'));
好的,我发现了问题。 问题是各方使用的密钥KEY。 当试图被PHP引导时,密钥出现了问题,这就是为什么它会创建不同的令牌。 这些库没问题,它们之间可以毫无问题地相互通信。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.