From 414918d9113b447c9ae774cdfd087f1636b8e5a0 Mon Sep 17 00:00:00 2001 From: Anthony Scarpino Date: Mon, 25 Apr 2022 15:31:49 +0000 Subject: [PATCH] 8285389: EdDSA trimming zeros Reviewed-by: xuelei --- .../share/classes/sun/security/ec/ed/EdDSAOperations.java | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/jdk.crypto.ec/share/classes/sun/security/ec/ed/EdDSAOperations.java b/src/jdk.crypto.ec/share/classes/sun/security/ec/ed/EdDSAOperations.java index c102453aac9..316c3009399 100644 --- a/src/jdk.crypto.ec/share/classes/sun/security/ec/ed/EdDSAOperations.java +++ b/src/jdk.crypto.ec/share/classes/sun/security/ec/ed/EdDSAOperations.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2020, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -134,6 +134,11 @@ public class EdDSAOperations { if (signature == null) { throw new SignatureException("signature was null"); } + + if (params.getKeyLength() * 2 != signature.length) { + throw new SignatureException("signature length invalid"); + } + byte[] encR = Arrays.copyOf(signature, signature.length / 2); byte[] encS = Arrays.copyOfRange(signature, signature.length / 2, signature.length);