PyJWT 引发签名验证失败
PyJWT raises Signature verification failed
我正在尝试验证由 ThingsBoard 发布的 JWT。
但是验证失败 Signature verification failed
我的测试代码在下面。
def test_jwt_decoding():
jwt_options = {
'verify_signature': True,
'verify_exp': True,
'verify_nbf': False,
'verify_iat': True,
'verify_aud': False
}
token = 'eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbkB0LW1vbmV0LmNvbSIsInNjb3BlcyI6WyJURU5BTlRfQURNSU4iXSwidXNlcklkIjoiODNiYmEzNDAtMDI3ZC0xMWU4LWI4ZmEtYWY1YjU0OTEyMDA0IiwiZmlyc3ROYW1lIjoi7ISx64Ko7IucIiwibGFzdE5hbWUiOiLqtIDrpqzsnpAiLCJlbmFibGVkIjp0cnVlLCJpc1B1YmxpYyI6ZmFsc2UsInRlbmFudElkIjoiMzkwMTNjNzAtMDI3ZC0xMWU4LWI4ZmEtYWY1YjU0OTEyMDA0IiwiY3VzdG9tZXJJZCI6IjEzODE0MDAwLTFkZDItMTFiMi04MDgwLTgwODA4MDgwODA4MCIsImlzcyI6InRoaW5nc2JvYXJkLmlvIiwiaWF0IjoxNTM1OTU1NDE2LCJleHAiOjM2NzU5NTU0MTZ9.N1Ms0LA7WtOel1pg6lTMRNDJosY3qfR6Q4SVuAUwmDPmTj4uYnKU0B-9Wdlqmg4HQRUXa23edOTU-TnAxfBoyg'
try:
jwt.decode(
token,
'thingsboardDefaultSigningKey',
algorithms=['HS512'],
options=jwt_options
)
assert True
except Exception as err:
print(str(err))
assert False
我检查了签名已在 jwt.io 验证
唯一的区别是 secret base64 encoded 在 jwt.io
我猜测 秘密 base64 编码 造成了这种差异。
我该怎么做?
jwt.decode(..)
期望密钥值是文本字符串中的实际秘密,没有编码。您的令牌似乎是用一个例程编码的,该例程期望秘密是 base64 编码的。很幸运,您的秘密 'thingsboardDefaultSigningKey' 恰好正确解码为 base64。
将您的呼叫更改为:
jwt.decode(
token,
b64decode('thingsboardDefaultSigningKey'),
algorithms=['HS512'],
options=jwt_options
)
然后会无一例外地解码
我正在尝试验证由 ThingsBoard 发布的 JWT。
但是验证失败 Signature verification failed
我的测试代码在下面。
def test_jwt_decoding():
jwt_options = {
'verify_signature': True,
'verify_exp': True,
'verify_nbf': False,
'verify_iat': True,
'verify_aud': False
}
token = 'eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbkB0LW1vbmV0LmNvbSIsInNjb3BlcyI6WyJURU5BTlRfQURNSU4iXSwidXNlcklkIjoiODNiYmEzNDAtMDI3ZC0xMWU4LWI4ZmEtYWY1YjU0OTEyMDA0IiwiZmlyc3ROYW1lIjoi7ISx64Ko7IucIiwibGFzdE5hbWUiOiLqtIDrpqzsnpAiLCJlbmFibGVkIjp0cnVlLCJpc1B1YmxpYyI6ZmFsc2UsInRlbmFudElkIjoiMzkwMTNjNzAtMDI3ZC0xMWU4LWI4ZmEtYWY1YjU0OTEyMDA0IiwiY3VzdG9tZXJJZCI6IjEzODE0MDAwLTFkZDItMTFiMi04MDgwLTgwODA4MDgwODA4MCIsImlzcyI6InRoaW5nc2JvYXJkLmlvIiwiaWF0IjoxNTM1OTU1NDE2LCJleHAiOjM2NzU5NTU0MTZ9.N1Ms0LA7WtOel1pg6lTMRNDJosY3qfR6Q4SVuAUwmDPmTj4uYnKU0B-9Wdlqmg4HQRUXa23edOTU-TnAxfBoyg'
try:
jwt.decode(
token,
'thingsboardDefaultSigningKey',
algorithms=['HS512'],
options=jwt_options
)
assert True
except Exception as err:
print(str(err))
assert False
我检查了签名已在 jwt.io 验证 唯一的区别是 secret base64 encoded 在 jwt.io
我猜测 秘密 base64 编码 造成了这种差异。
我该怎么做?
jwt.decode(..)
期望密钥值是文本字符串中的实际秘密,没有编码。您的令牌似乎是用一个例程编码的,该例程期望秘密是 base64 编码的。很幸运,您的秘密 'thingsboardDefaultSigningKey' 恰好正确解码为 base64。
将您的呼叫更改为:
jwt.decode(
token,
b64decode('thingsboardDefaultSigningKey'),
algorithms=['HS512'],
options=jwt_options
)
然后会无一例外地解码