我有一个用Python编写的API和另一个用Ruby编写的API。我们需要它们在彼此之间发送数据,并已决定使用JWT作为身份验证方法。基本上在任一端都生成令牌,并确保它们匹配。现在我在python和ruby之间有匹配的哈希值问题。给定此代码:python(2.7)PyJWT == 1.6.4>>> import jwt>>> jwt.encode({"someKey":123}, "secret", algorithm='HS256')u'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzb21lS2V5IjoxMjN9.DL8qyWMeqfMMLCTPN3RA9K08e-AkNW_ybPyywvrIIZ8'这似乎在python版本之间也发生了变化-在python3上运行时产生了这个b'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJhcHBlbklkIjoxMjN9.YgFKZePJYMRDMgubCeZBy6WaFKiTA9C-TRnnZLFJC8E'然后,当我在ruby中创建类似的“函数”时,我得到了不同的哈希值-这在ruby的jwt版本之间也是如此(我已经测试过jwt-1.5.6和jwt-2.1.0)-下面是jwt-1.5 .6结果。require "jwt"someKey = 123secret = "secret"payload = {"someKey" => someKey}token = JWT.encode payload, secret, 'HS256'puts token该代码的输出是eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzb21lS2V5IjoxMjN9.7Ch3o7IXmxqm79AcrTetXuZv6h3suyLD5_IgXdrRlNs使用版本jwt-2.1.0,我得到:eyJhbGciOiJIUzI1NiJ9.eyJzb21lS2V5IjoxMjN9.QkKm2IuvOz_D5ukIxOsjMYApzV2ZnjLE2HII3ZfP_hsWith为什么这两个代码集的输出会产生两个不同的哈希值?编辑:当我使用jwt.iohttps://jwt.io/#debugger-io?token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzb21lS2V5IjoxMjN9.DL8qyWMeqfMMLCTPN3RA9K08e-AkNW_ybPyywvr我得到与python相同的令牌
2 回答
慕神8447489
TA贡献1780条经验 获得超1个赞
无需在双方都创建令牌。结合使用JWT策略和pub私钥算法RS256
。这样,您可以在一个API中签名JWT令牌,并能够在另一个API中使用公钥进行验证。
慕虎7371278
TA贡献1802条经验 获得超4个赞
所以我解决了这个问题,正如@jps提到的那样,Ruby代码没有标头{“ typ”:“ JWT”}-python代码没有。正如在ruby jwt的文档中提到的,您可以设置标题。这是将其固定在红宝石端的代码。
token = JWT.encode(payload=payload, key=key, algorithm='HS256',header_fields={ typ: 'JWT' })
现在,令牌已匹配。顺便说一句,即使是不同的哈希,也可以通过相同的秘密进行解码-身份验证中只有一个额外的步骤,即再次检查创建的哈希红宝石是否与传入的哈希匹配。
添加回答
举报
0/150
提交
取消