2017-03-10 68 views
9

所以我在python中有一个客户端,而在PHP中有一个后端。 python客户端使用pyjwt,php服务器使用Firebase JWTFirebase JWT库无法验证Python JWT令牌

当在php内编码和解码令牌时,一切正常。但是,当我编码蟒蛇令牌,并将它们与PHP中的火力地堡库解码返回一个错误:

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')); 

回答

2

好的,我发现了这个问题。问题在于不同方面使用的秘密KEY。当试图被PHP推荐时,关键有一个问题,那就是为什么它会创建不同的标记。图书馆没问题,他们可以相互沟通,没有任何问题。