From 5161ab9493c87313aa8b7d3e1a8a829f6254c993 Mon Sep 17 00:00:00 2001 From: Xue-Lei Andrew Fan Date: Thu, 21 Nov 2019 18:42:33 -0800 Subject: [PATCH] 8233954: UnsatisfiedLinkError or NoSuchAlgorithmException after removing sunec.dll Reviewed-by: ascarpino --- .../classes/sun/security/ssl/NamedGroup.java | 11 +++++++ .../sun/security/ssl/SignatureScheme.java | 33 ++++++++++++------- 2 files changed, 33 insertions(+), 11 deletions(-) diff --git a/src/java.base/share/classes/sun/security/ssl/NamedGroup.java b/src/java.base/share/classes/sun/security/ssl/NamedGroup.java index bade8568d4a..0e7a5347371 100644 --- a/src/java.base/share/classes/sun/security/ssl/NamedGroup.java +++ b/src/java.base/share/classes/sun/security/ssl/NamedGroup.java @@ -250,8 +250,19 @@ enum NamedGroup { this.supportedProtocols = supportedProtocols; this.keAlgParamSpec = keAlgParamSpec; + // Check if it is a supported named group. AlgorithmParameters algParams = null; boolean mediator = (keAlgParamSpec != null); + + // HACK CODE + // + // An EC provider, for example the SunEC provider, may support + // AlgorithmParameters but not KeyPairGenerator or KeyAgreement. + if (mediator && (namedGroupSpec == NamedGroupSpec.NAMED_GROUP_ECDHE)) { + mediator = JsseJce.isEcAvailable(); + } + + // Check the specific algorithm parameters. if (mediator) { try { algParams = diff --git a/src/java.base/share/classes/sun/security/ssl/SignatureScheme.java b/src/java.base/share/classes/sun/security/ssl/SignatureScheme.java index 7aa9a86399a..7b4b204a019 100644 --- a/src/java.base/share/classes/sun/security/ssl/SignatureScheme.java +++ b/src/java.base/share/classes/sun/security/ssl/SignatureScheme.java @@ -274,17 +274,28 @@ enum SignatureScheme { Arrays.asList(handshakeSupportedProtocols); boolean mediator = true; - if (signAlgParams != null) { - mediator = signAlgParams.isAvailable; - } else { - try { - Signature.getInstance(algorithm); - } catch (Exception e) { - mediator = false; - if (SSLLogger.isOn && SSLLogger.isOn("ssl,handshake")) { - SSLLogger.warning( - "Signature algorithm, " + algorithm + - ", is not supported by the underlying providers"); + // HACK CODE + // + // An EC provider, for example the SunEC provider, may support + // AlgorithmParameters but not KeyPairGenerator or Signature. + if ("EC".equals(keyAlgorithm)) { + mediator = JsseJce.isEcAvailable(); + } + + // Check the specific algorithm and parameters. + if (mediator) { + if (signAlgParams != null) { + mediator = signAlgParams.isAvailable; + } else { + try { + Signature.getInstance(algorithm); + } catch (Exception e) { + mediator = false; + if (SSLLogger.isOn && SSLLogger.isOn("ssl,handshake")) { + SSLLogger.warning( + "Signature algorithm, " + algorithm + + ", is not supported by the underlying providers"); + } } } }