Firebase JWT库无法验证Python JWT令牌

时间:2017-03-10 11:07:24

标签: php python firebase token jwt

所以我在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'));

1 个答案:

答案 0 :(得分:2)

好的,我发现了问题。问题是各方使用的密钥KEY。当试图被PHP引导时,密钥出现了问题,这就是为什么它会创建不同的令牌。这些库没问题,它们之间可以毫无问题地进行通信。