← voltar
CVE-2022-23541

jsonwebtoken's insecure implementation of key retrieval function could lead to Forgeable Public/Private Tokens from RSA to HMAC

CVSS 5 MEDIUMEPSS 0.8%CWE-1259CWE-287
Em resumo

A biblioteca jsonwebtoken (versões ≤ 8.5.1) pode verificar tokens JWT incorretamente se a função de recuperação de chaves for mal implementada, permitindo que atacantes criem tokens forjados trocando o algoritmo de assimétrico (RSA) para simétrico (HMAC). Isso ocorre porque a biblioteca pode aceitar tokens assinados com um algoritmo mas verificados com outro.

Detalhe técnico

A vulnerabilidade existe no mecanismo de recuperação de chaves do jsonwebtoken ≤ 8.5.1, onde má configuração permite ataques de confusão de algoritmos. Um atacante pode forjar tokens explorando funções de recuperação de chaves fracas que não garantem consistência de algoritmo entre assinatura e verificação, permitindo que tokens assinados com RSA sejam validados usando HMAC com chave simétrica. Pré-condição: aplicação deve usar chaves simétricas e assimétricas na mesma função jwt.verify().

Resumo gerado e traduzido por IA a partir da descrição oficial.
jsonwebtoken is an implementation of JSON Web Tokens. Versions `<= 8.5.1` of `jsonwebtoken` library can be misconfigured so that passing a poorly implemented key retrieval function referring to the `secretOrPublicKey` argument from the readme link will result in incorrect verification of tokens. There is a possibility of using a different algorithm and key combination in verification, other than the one that was used to sign the tokens. Specifically, tokens signed with an asymmetric public key could be verified with a symmetric HS256 algorithm. This can lead to successful validation of forged tokens. If your application is supporting usage of both symmetric key and asymmetric key in jwt.verify() implementation with the same key retrieval function. This issue has been patched, please update to version 9.0.0.
CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:L

Quer saber se a sua infraestrutura está exposta a isto?

Falar com a TrueHacking →