116 lines
4.3 KiB
Java
Raw Normal View History

/*
* Copyright (c) 2017, 2019, 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
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
import java.security.NoSuchAlgorithmException;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLParameters;
import javax.net.ssl.SSLSocketFactory;
/*
* This class is used for returning some specific JDK information.
*/
public class JdkUtils {
public static final String JAVA_RUNTIME_VERSION = "javaRuntimeVersion";
public static final String SUPPORTED_PROTOCOLS = "supportedProtocols";
public static final String SUPPORTED_CIPHER_SUITES = "supportedCipherSuites";
public static final String SUPPORTS_SNI = "supportsSNI";
public static final String SUPPORTS_ALPN = "supportsALPN";
// Returns the JDK build version.
public static String javaRuntimeVersion() {
return System.getProperty("java.runtime.version");
}
private static String supportedProtocols() {
StringBuilder protocols = new StringBuilder();
for (String protocol : new String[] {
"TLSv1", "TLSv1.1", "TLSv1.2", "TLSv1.3" }) {
if (supportsProtocol(protocol)) {
protocols.append(protocol).append(Utils.VALUE_DELIMITER);
}
}
return protocols.toString().substring(
0, protocols.toString().length() - 1);
}
private static boolean supportsProtocol(String protocol) {
boolean supported = true;
try {
SSLContext.getInstance(protocol);
} catch (NoSuchAlgorithmException e) {
supported = false;
}
return supported;
}
private static String supportedCipherSuites() {
StringBuilder cipherSuites = new StringBuilder();
String[] supportedCipherSuites = ((SSLSocketFactory) SSLSocketFactory
.getDefault()).getSupportedCipherSuites();
for (int i = 0; i < supportedCipherSuites.length - 1; i++) {
cipherSuites.append(supportedCipherSuites[i])
.append(Utils.VALUE_DELIMITER);
}
cipherSuites.append(
supportedCipherSuites[supportedCipherSuites.length - 1]);
return cipherSuites.toString();
}
// Checks if SNI is supported by the JDK build.
private static boolean supportsSNI() {
boolean isSupported = true;
try {
SSLParameters.class.getMethod("getServerNames");
} catch (NoSuchMethodException e) {
isSupported = false;
}
return isSupported;
}
// Checks if ALPN is supported by the JDK build.
private static boolean supportsALPN() {
boolean isSupported = true;
try {
SSLParameters.class.getMethod("getApplicationProtocols");
} catch (NoSuchMethodException e) {
isSupported = false;
}
return isSupported;
}
public static void main(String[] args) throws NoSuchAlgorithmException {
System.out.print(Utils.join(Utils.PARAM_DELIMITER,
attr(JAVA_RUNTIME_VERSION, javaRuntimeVersion()),
attr(SUPPORTED_PROTOCOLS, supportedProtocols()),
attr(SUPPORTED_CIPHER_SUITES, supportedCipherSuites()),
attr(SUPPORTS_SNI, supportsSNI()),
attr(SUPPORTS_ALPN, supportsALPN())));
}
private static String attr(String name, Object value) {
return name + "=" + String.valueOf(value);
}
}