Launch Week Day 1: Announcing Security Design Review
HIGH 7.5 PyPI

PyJWT vulnerable to key confusion attacks

GHSA-r9jw-mwhq-wp62 · CVE-2017-11424 · PYSEC-2017-24

Published · Modified

Description

In PyJWT 1.5.0 and below the invalid_strings check in HMACAlgorithm.prepare_key does not account for all PEM encoded public keys. Specifically, the PKCS1 PEM encoded format would be allowed because it is prefaced with the string -----BEGIN RSA PUBLIC KEY----- which is not accounted for. This enables symmetric/asymmetric key confusion attacks against users using the PKCS1 PEM encoded public keys, which would allow an attacker to craft JWTs from scratch.

Ready to move

Start Securing

Free, no credit card | First findings in minutes