所以我在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'));
答案 0 :(得分:2)
好的,我发现了问题。问题是各方使用的密钥KEY。当试图被PHP引导时,密钥出现了问题,这就是为什么它会创建不同的令牌。这些库没问题,它们之间可以毫无问题地进行通信。