
Psychic Signatures: lo que necesita saber
El 19 de abril de 2022, Neil Madden reveló una vulnerabilidad in Oracle Java 15 a 18 and OpenJDK 15, 17 and 18. La vulnerabilidad reside en la criptografía de las firmas ECDSA, que permite a un atacante eludir por completo las comprobaciones de estas firmas.
Es fácil ver los titulares sobre esta vulnerabilidad y pasarlos por alto, dada la naturaleza poco clara de las firmas de la ECDSA. Sin embargo, las firmas de la ECDSA en realidad desempeñan un papel clave en la protección de los sistemas de Internet para tareas críticas como la autenticación.
Antes de profundizar en los detalles, si quieres experimentar cómo los piratas informáticos explotan Psychic Signatures de forma práctica. Salta directamente a nuestro laboratorio gratuito - Misiones para probarlo tú mismo.
What is the problem with ECDSA?
Es posible que no haya oído hablar de la ECDSA antes. Es la abreviatura del algoritmo de firma digital de curva elíptica, que es un tipo de criptografía que utiliza las propiedades matemáticas de las curvas elípticas y ofrece una de las medidas de seguridad criptográficas más sólidas del sector en la actualidad.
Esto significa que se usa para muchas funciones importantes, como:
- La firma de certificados SSL
- Pretones de manos durante las comunicaciones cifradas
- SAML
- Firmas de JWT
- OpenID Connect Firmes
Esto significa que la ECDSA es una parte clave de muchas de las funciones más delicadas para proteger los sistemas que existen. La capacidad de eludir las verificaciones de firmas podría ser bastante devastadora.
¿Cómo se explota la vulnerabilidad?
Desafortunadamente, las matemáticas del ECDSA son algo complicadas. Pero lo más importante que hay que saber es que una firma del ECDSA contiene dos datos: Por lo tanto, y s.
Estos números se utilizan para calcular la validez de la firma. El valor r es el «resultado» (lado izquierdo) de un cálculo que utiliza ambos r y s en el lado derecho de la ecuación. Dado que multiplicar por 0 es una mala idea, la especificación ECDSA indica explícitamente que si el valor de r o s siempre es 0, deben descartarse.
Pero la implementación de ECDSA en Java olvidó tener esto en cuenta. Por lo tanto, aceptará la firma de ambos r y s es 0, lo que siempre será cierto. Podemos demostrarlo con un ejemplo de un JWT, mostrando lo fácil que es. ¿Usando https://token.dev/, podemos generar un token con el algoritmo ES256, similar a lo que generaría una aplicación:

Recuerde que un JWT se divide en 3 partes:
- Encabezado (en azul)
- Carga útil (en verde)
- Firma (en rojo)
Ahora, si quisiéramos saltarnos la verificación de firmas, ¿cómo lo haríamos? La firma especifica los valores de r Y sí, y está codificado en formato DER.

Cambiemos nuestro JWT para usar esta nueva firma. Tenga en cuenta que en los JWT, el signo igual no está incluido.

Ahora, nuestra firma tiene r y s establecido en 0 y, en las versiones vulnerables de Java, la comprobación de firmas ahora se realizará correctamente para cualquier carga útil que especifique.
¿Quién se ve afectado y cómo mitigarlo?
La vulnerabilidad afecta tanto a Oracle Java como a OpenJDK. Entre ellas se incluyen:
Oracle Java SE (y versiones anteriores no compatibles):
- 18
- 17,02
Oracle Enterprise Edition GraalVM:
- 22,0,02
- 213,1
OpenJDK :
- 18
- 17,02
- 15,06
- 13,0,10
- 11,0,14
- 8u322
- 7u331
Ambos Oráculo y OpenJDK han publicado avisos y parches para el problema que se pueden aplicar de inmediato.
Prácticas prácticas para defenderse de esta vulnerabilidad
En Secure Code Warrior, nos esforzamos por proporcionar a los desarrolladores la información más relevante y los ejercicios prácticos para las vulnerabilidades críticas, ya sea una más reciente, como Psychic Signatures, o algo que existe desde hace años.
Creemos que, para mantener realmente a raya el riesgo, es necesario permitir a los desarrolladores comprender el mecanismo de defensa y escribir código seguro desde el principio. Por eso, hemos creado una guía paso a paso sobre esta vulnerabilidad (y muchas otras) para ti y para los equipos afectados.
En el tutorial, podrás seguir las instrucciones para aprovechar la firma física en JWTS y ver el impacto en una aplicación que funciona en tiempo real.
Pruébalo ahora.


La vulnerabilidad de Psychic Signature reside en la criptografía de las firmas ECDSA, que protege los sistemas para tareas críticas como la autenticación. Con esta vulnerabilidad, los piratas informáticos pueden eludir cualquier comprobación de firmas. Explicamos qué es y cómo mitigarla en este post.

Secure Code Warrior là pour aider votre organisation à protéger le code tout au long du cycle de vie du développement logiciel et à créer une culture où la cybersécurité est une priorité. Que vous soyez administrateur AppSec, développeur, CISO ou toute autre personne impliquée dans la sécurité, nous pouvons aider votre organisation à réduire les risques associés à un code non sécurisé.
Veuillez réserver une démonstration.

El 19 de abril de 2022, Neil Madden reveló una vulnerabilidad in Oracle Java 15 a 18 and OpenJDK 15, 17 and 18. La vulnerabilidad reside en la criptografía de las firmas ECDSA, que permite a un atacante eludir por completo las comprobaciones de estas firmas.
Es fácil ver los titulares sobre esta vulnerabilidad y pasarlos por alto, dada la naturaleza poco clara de las firmas de la ECDSA. Sin embargo, las firmas de la ECDSA en realidad desempeñan un papel clave en la protección de los sistemas de Internet para tareas críticas como la autenticación.
Antes de profundizar en los detalles, si quieres experimentar cómo los piratas informáticos explotan Psychic Signatures de forma práctica. Salta directamente a nuestro laboratorio gratuito - Misiones para probarlo tú mismo.
What is the problem with ECDSA?
Es posible que no haya oído hablar de la ECDSA antes. Es la abreviatura del algoritmo de firma digital de curva elíptica, que es un tipo de criptografía que utiliza las propiedades matemáticas de las curvas elípticas y ofrece una de las medidas de seguridad criptográficas más sólidas del sector en la actualidad.
Esto significa que se usa para muchas funciones importantes, como:
- La firma de certificados SSL
- Pretones de manos durante las comunicaciones cifradas
- SAML
- Firmas de JWT
- OpenID Connect Firmes
Esto significa que la ECDSA es una parte clave de muchas de las funciones más delicadas para proteger los sistemas que existen. La capacidad de eludir las verificaciones de firmas podría ser bastante devastadora.
¿Cómo se explota la vulnerabilidad?
Desafortunadamente, las matemáticas del ECDSA son algo complicadas. Pero lo más importante que hay que saber es que una firma del ECDSA contiene dos datos: Por lo tanto, y s.
Estos números se utilizan para calcular la validez de la firma. El valor r es el «resultado» (lado izquierdo) de un cálculo que utiliza ambos r y s en el lado derecho de la ecuación. Dado que multiplicar por 0 es una mala idea, la especificación ECDSA indica explícitamente que si el valor de r o s siempre es 0, deben descartarse.
Pero la implementación de ECDSA en Java olvidó tener esto en cuenta. Por lo tanto, aceptará la firma de ambos r y s es 0, lo que siempre será cierto. Podemos demostrarlo con un ejemplo de un JWT, mostrando lo fácil que es. ¿Usando https://token.dev/, podemos generar un token con el algoritmo ES256, similar a lo que generaría una aplicación:

Recuerde que un JWT se divide en 3 partes:
- Encabezado (en azul)
- Carga útil (en verde)
- Firma (en rojo)
Ahora, si quisiéramos saltarnos la verificación de firmas, ¿cómo lo haríamos? La firma especifica los valores de r Y sí, y está codificado en formato DER.

Cambiemos nuestro JWT para usar esta nueva firma. Tenga en cuenta que en los JWT, el signo igual no está incluido.

Ahora, nuestra firma tiene r y s establecido en 0 y, en las versiones vulnerables de Java, la comprobación de firmas ahora se realizará correctamente para cualquier carga útil que especifique.
¿Quién se ve afectado y cómo mitigarlo?
La vulnerabilidad afecta tanto a Oracle Java como a OpenJDK. Entre ellas se incluyen:
Oracle Java SE (y versiones anteriores no compatibles):
- 18
- 17,02
Oracle Enterprise Edition GraalVM:
- 22,0,02
- 213,1
OpenJDK :
- 18
- 17,02
- 15,06
- 13,0,10
- 11,0,14
- 8u322
- 7u331
Ambos Oráculo y OpenJDK han publicado avisos y parches para el problema que se pueden aplicar de inmediato.
Prácticas prácticas para defenderse de esta vulnerabilidad
En Secure Code Warrior, nos esforzamos por proporcionar a los desarrolladores la información más relevante y los ejercicios prácticos para las vulnerabilidades críticas, ya sea una más reciente, como Psychic Signatures, o algo que existe desde hace años.
Creemos que, para mantener realmente a raya el riesgo, es necesario permitir a los desarrolladores comprender el mecanismo de defensa y escribir código seguro desde el principio. Por eso, hemos creado una guía paso a paso sobre esta vulnerabilidad (y muchas otras) para ti y para los equipos afectados.
En el tutorial, podrás seguir las instrucciones para aprovechar la firma física en JWTS y ver el impacto en una aplicación que funciona en tiempo real.
Pruébalo ahora.

El 19 de abril de 2022, Neil Madden reveló una vulnerabilidad in Oracle Java 15 a 18 and OpenJDK 15, 17 and 18. La vulnerabilidad reside en la criptografía de las firmas ECDSA, que permite a un atacante eludir por completo las comprobaciones de estas firmas.
Es fácil ver los titulares sobre esta vulnerabilidad y pasarlos por alto, dada la naturaleza poco clara de las firmas de la ECDSA. Sin embargo, las firmas de la ECDSA en realidad desempeñan un papel clave en la protección de los sistemas de Internet para tareas críticas como la autenticación.
Antes de profundizar en los detalles, si quieres experimentar cómo los piratas informáticos explotan Psychic Signatures de forma práctica. Salta directamente a nuestro laboratorio gratuito - Misiones para probarlo tú mismo.
What is the problem with ECDSA?
Es posible que no haya oído hablar de la ECDSA antes. Es la abreviatura del algoritmo de firma digital de curva elíptica, que es un tipo de criptografía que utiliza las propiedades matemáticas de las curvas elípticas y ofrece una de las medidas de seguridad criptográficas más sólidas del sector en la actualidad.
Esto significa que se usa para muchas funciones importantes, como:
- La firma de certificados SSL
- Pretones de manos durante las comunicaciones cifradas
- SAML
- Firmas de JWT
- OpenID Connect Firmes
Esto significa que la ECDSA es una parte clave de muchas de las funciones más delicadas para proteger los sistemas que existen. La capacidad de eludir las verificaciones de firmas podría ser bastante devastadora.
¿Cómo se explota la vulnerabilidad?
Desafortunadamente, las matemáticas del ECDSA son algo complicadas. Pero lo más importante que hay que saber es que una firma del ECDSA contiene dos datos: Por lo tanto, y s.
Estos números se utilizan para calcular la validez de la firma. El valor r es el «resultado» (lado izquierdo) de un cálculo que utiliza ambos r y s en el lado derecho de la ecuación. Dado que multiplicar por 0 es una mala idea, la especificación ECDSA indica explícitamente que si el valor de r o s siempre es 0, deben descartarse.
Pero la implementación de ECDSA en Java olvidó tener esto en cuenta. Por lo tanto, aceptará la firma de ambos r y s es 0, lo que siempre será cierto. Podemos demostrarlo con un ejemplo de un JWT, mostrando lo fácil que es. ¿Usando https://token.dev/, podemos generar un token con el algoritmo ES256, similar a lo que generaría una aplicación:

Recuerde que un JWT se divide en 3 partes:
- Encabezado (en azul)
- Carga útil (en verde)
- Firma (en rojo)
Ahora, si quisiéramos saltarnos la verificación de firmas, ¿cómo lo haríamos? La firma especifica los valores de r Y sí, y está codificado en formato DER.

Cambiemos nuestro JWT para usar esta nueva firma. Tenga en cuenta que en los JWT, el signo igual no está incluido.

Ahora, nuestra firma tiene r y s establecido en 0 y, en las versiones vulnerables de Java, la comprobación de firmas ahora se realizará correctamente para cualquier carga útil que especifique.
¿Quién se ve afectado y cómo mitigarlo?
La vulnerabilidad afecta tanto a Oracle Java como a OpenJDK. Entre ellas se incluyen:
Oracle Java SE (y versiones anteriores no compatibles):
- 18
- 17,02
Oracle Enterprise Edition GraalVM:
- 22,0,02
- 213,1
OpenJDK :
- 18
- 17,02
- 15,06
- 13,0,10
- 11,0,14
- 8u322
- 7u331
Ambos Oráculo y OpenJDK han publicado avisos y parches para el problema que se pueden aplicar de inmediato.
Prácticas prácticas para defenderse de esta vulnerabilidad
En Secure Code Warrior, nos esforzamos por proporcionar a los desarrolladores la información más relevante y los ejercicios prácticos para las vulnerabilidades críticas, ya sea una más reciente, como Psychic Signatures, o algo que existe desde hace años.
Creemos que, para mantener realmente a raya el riesgo, es necesario permitir a los desarrolladores comprender el mecanismo de defensa y escribir código seguro desde el principio. Por eso, hemos creado una guía paso a paso sobre esta vulnerabilidad (y muchas otras) para ti y para los equipos afectados.
En el tutorial, podrás seguir las instrucciones para aprovechar la firma física en JWTS y ver el impacto en una aplicación que funciona en tiempo real.
Pruébalo ahora.

Veuillez cliquer sur le lien ci-dessous et télécharger le PDF de cette ressource.
Secure Code Warrior là pour aider votre organisation à protéger le code tout au long du cycle de vie du développement logiciel et à créer une culture où la cybersécurité est une priorité. Que vous soyez administrateur AppSec, développeur, CISO ou toute autre personne impliquée dans la sécurité, nous pouvons aider votre organisation à réduire les risques associés à un code non sécurisé.
Veuillez consulter le rapportVeuillez réserver une démonstration.El 19 de abril de 2022, Neil Madden reveló una vulnerabilidad in Oracle Java 15 a 18 and OpenJDK 15, 17 and 18. La vulnerabilidad reside en la criptografía de las firmas ECDSA, que permite a un atacante eludir por completo las comprobaciones de estas firmas.
Es fácil ver los titulares sobre esta vulnerabilidad y pasarlos por alto, dada la naturaleza poco clara de las firmas de la ECDSA. Sin embargo, las firmas de la ECDSA en realidad desempeñan un papel clave en la protección de los sistemas de Internet para tareas críticas como la autenticación.
Antes de profundizar en los detalles, si quieres experimentar cómo los piratas informáticos explotan Psychic Signatures de forma práctica. Salta directamente a nuestro laboratorio gratuito - Misiones para probarlo tú mismo.
What is the problem with ECDSA?
Es posible que no haya oído hablar de la ECDSA antes. Es la abreviatura del algoritmo de firma digital de curva elíptica, que es un tipo de criptografía que utiliza las propiedades matemáticas de las curvas elípticas y ofrece una de las medidas de seguridad criptográficas más sólidas del sector en la actualidad.
Esto significa que se usa para muchas funciones importantes, como:
- La firma de certificados SSL
- Pretones de manos durante las comunicaciones cifradas
- SAML
- Firmas de JWT
- OpenID Connect Firmes
Esto significa que la ECDSA es una parte clave de muchas de las funciones más delicadas para proteger los sistemas que existen. La capacidad de eludir las verificaciones de firmas podría ser bastante devastadora.
¿Cómo se explota la vulnerabilidad?
Desafortunadamente, las matemáticas del ECDSA son algo complicadas. Pero lo más importante que hay que saber es que una firma del ECDSA contiene dos datos: Por lo tanto, y s.
Estos números se utilizan para calcular la validez de la firma. El valor r es el «resultado» (lado izquierdo) de un cálculo que utiliza ambos r y s en el lado derecho de la ecuación. Dado que multiplicar por 0 es una mala idea, la especificación ECDSA indica explícitamente que si el valor de r o s siempre es 0, deben descartarse.
Pero la implementación de ECDSA en Java olvidó tener esto en cuenta. Por lo tanto, aceptará la firma de ambos r y s es 0, lo que siempre será cierto. Podemos demostrarlo con un ejemplo de un JWT, mostrando lo fácil que es. ¿Usando https://token.dev/, podemos generar un token con el algoritmo ES256, similar a lo que generaría una aplicación:

Recuerde que un JWT se divide en 3 partes:
- Encabezado (en azul)
- Carga útil (en verde)
- Firma (en rojo)
Ahora, si quisiéramos saltarnos la verificación de firmas, ¿cómo lo haríamos? La firma especifica los valores de r Y sí, y está codificado en formato DER.

Cambiemos nuestro JWT para usar esta nueva firma. Tenga en cuenta que en los JWT, el signo igual no está incluido.

Ahora, nuestra firma tiene r y s establecido en 0 y, en las versiones vulnerables de Java, la comprobación de firmas ahora se realizará correctamente para cualquier carga útil que especifique.
¿Quién se ve afectado y cómo mitigarlo?
La vulnerabilidad afecta tanto a Oracle Java como a OpenJDK. Entre ellas se incluyen:
Oracle Java SE (y versiones anteriores no compatibles):
- 18
- 17,02
Oracle Enterprise Edition GraalVM:
- 22,0,02
- 213,1
OpenJDK :
- 18
- 17,02
- 15,06
- 13,0,10
- 11,0,14
- 8u322
- 7u331
Ambos Oráculo y OpenJDK han publicado avisos y parches para el problema que se pueden aplicar de inmediato.
Prácticas prácticas para defenderse de esta vulnerabilidad
En Secure Code Warrior, nos esforzamos por proporcionar a los desarrolladores la información más relevante y los ejercicios prácticos para las vulnerabilidades críticas, ya sea una más reciente, como Psychic Signatures, o algo que existe desde hace años.
Creemos que, para mantener realmente a raya el riesgo, es necesario permitir a los desarrolladores comprender el mecanismo de defensa y escribir código seguro desde el principio. Por eso, hemos creado una guía paso a paso sobre esta vulnerabilidad (y muchas otras) para ti y para los equipos afectados.
En el tutorial, podrás seguir las instrucciones para aprovechar la firma física en JWTS y ver el impacto en una aplicación que funciona en tiempo real.
Pruébalo ahora.
Table des matières

Secure Code Warrior là pour aider votre organisation à protéger le code tout au long du cycle de vie du développement logiciel et à créer une culture où la cybersécurité est une priorité. Que vous soyez administrateur AppSec, développeur, CISO ou toute autre personne impliquée dans la sécurité, nous pouvons aider votre organisation à réduire les risques associés à un code non sécurisé.
Veuillez réserver une démonstration.TéléchargerRessources pour débuter
Thèmes et contenu de la formation sur le code sécurisé
Notre contenu de pointe évolue constamment afin de s'adapter au paysage changeant du développement logiciel, en tenant compte de votre rôle. Nous proposons des thèmes allant de l'IA à l'injection XQuery pour différents postes, des architectes et ingénieurs aux chefs de produit et responsables de l'assurance qualité. Découvrez un aperçu de ce que notre catalogue de contenu a à offrir par thème et par fonction.
La Chambre de commerce établit la norme en matière de sécurité à grande échelle axée sur les développeurs
La Chambre de commerce néerlandaise explique comment elle a intégré le codage sécurisé dans le développement quotidien grâce à des certifications basées sur les rôles, à l'évaluation comparative du Trust Score et à une culture de responsabilité partagée en matière de sécurité.
Modélisation des menaces avec l'IA : transformer chaque développeur en modélisateur de menaces
Vous repartirez mieux équipé pour aider les développeurs à combiner les idées et les techniques de modélisation des menaces avec les outils d'IA qu'ils utilisent déjà pour renforcer la sécurité, améliorer la collaboration et créer des logiciels plus résilients dès le départ.
Ressources pour débuter
Cybermon est de retour : les missions IA de Beat the Boss sont désormais disponibles à la demande.
Cybermon 2025 Beat the Boss est désormais disponible toute l'année chez SCW. Mettez en œuvre des défis de sécurité avancés basés sur l'IA et le LLM afin de renforcer le développement sécurisé de l'IA à grande échelle.
Explication de la loi sur la cyber-résilience : implications pour le développement de logiciels sécurisés dès leur conception
Découvrez les exigences de la loi européenne sur la cyber-résilience (CRA), à qui elle s'applique et comment les équipes d'ingénierie peuvent se préparer grâce à des pratiques de conception sécurisées, à la prévention des vulnérabilités et au développement des compétences des développeurs.
Facilitateur 1 : Critères de réussite définis et mesurables
Le catalyseur n° 1 inaugure notre série en 10 parties intitulée « Les catalyseurs de la réussite », qui montre comment relier la codification sécurisée aux résultats commerciaux, tels que la réduction des risques et la rapidité d'atteinte de la maturité du programme à long terme.




%20(1).avif)
.avif)
