Symfony Vulnerable to Identity Spoofing via Unanchored DN Regex in X509Authenticator
Package
Affected versions
< 5.4.52
>= 6.0.0-BETA1, < 6.4.40
>= 7.0.0-BETA1, < 7.4.12
>= 8.0.0-BETA1, < 8.0.12
Patched versions
5.4.52
6.4.40
7.4.12
8.0.12
< 5.4.52
>= 6.0.0-BETA1, < 6.4.40
>= 7.0.0-BETA1, < 7.4.12
>= 8.0.0-BETA1, < 8.0.12
5.4.52
6.4.40
7.4.12
8.0.12
Description
Published to the GitHub Advisory Database
May 27, 2026
Reviewed
May 27, 2026
Last updated
May 27, 2026
Description
X509Authenticatorimplements client-certificate (mTLS) authentication: the web server validates the client's certificate against a trusted CA, then passes the certificate's Subject DN (Distinguished Name: a string likeCN=Alice,O=Example,emailAddress=alice@example.com) to Symfony via$_SERVER['SSL_CLIENT_S_DN']. Symfony extracts the user identifier from that string.The extraction uses an unanchored regex that matches
emailAddress=anywhere in the DN string: including inside the value of a different RDN (Relative Distinguished Name: onekey=valuecomponent of the DN), such asCN. An attacker who can obtain a certificate from a trusted CA with a free-textCNcan smuggleemailAddress=victim@targetinside the CN value and be authenticated as the victim.Resolution
The
X509Authenticatornow uses a regex that anchors the match to an RDN boundary (start of string, or following a,//separator).The patch for this issue is available here for branch 5.4.
Credits
Symfony would like to thank Claude Mythos Preview (via Project Glasswing) for reporting the issue and providing the fix.
References