Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Сегодня я перешел с Java 1.6 на Java 1.7. С 9X_javax тех пор, когда я пытаюсь установить соединение 9X_java-api с моим веб-сервером через SSL, возникает 9X_core-java ошибка:
javax.net.ssl.SSLProtocolException: handshake alert: unrecognized_name at sun.security.ssl.ClientHandshaker.handshakeAlert(ClientHandshaker.java:1288) at sun.security.ssl.SSLSocketImpl.recvAlert(SSLSocketImpl.java:1904) at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1027) at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1262) at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1289) at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1273) at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:523) at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185) at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1296) at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254) at java.net.URL.openStream(URL.java:1035)
Вот код:
SAXBuilder builder = new SAXBuilder(); Document document = null; try { url = new URL(https://some url); document = (Document) builder.build(url.openStream()); } catch (NoSuchAlgorithmException ex) { Logger.getLogger(DownloadLoadiciousComputer.class.getName()).log(Level.SEVERE, null, ex); }
Это всего лишь тестовый проект, поэтому 9X_jre я разрешаю и использую ненадежные сертификаты 9X_java с кодом:
TrustManager[] trustAllCerts = new TrustManager[]{ new X509TrustManager() { public java.security.cert.X509Certificate[] getAcceptedIssuers() { return null; } public void checkClientTrusted( java.security.cert.X509Certificate[] certs, String authType) { } public void checkServerTrusted( java.security.cert.X509Certificate[] certs, String authType) { } } }; try { SSLContext sc = SSLContext.getInstance("SSL"); sc.init(null, trustAllCerts, new java.security.SecureRandom()); HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory()); } catch (Exception e) { Logger.getLogger(DownloadManager.class.getName()).log(Level.SEVERE, null, e); }
Мне удалось подключиться к https://google.com. в чем 9X_jre моя вина?
Спасибо.
Ответ #1
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
В Java 7 появилась поддержка SNI, которая 9X_ssl включена по умолчанию. Я обнаружил, что 9X_java-api некоторые неправильно настроенные серверы 9X_java-libraries отправляют предупреждение «Нераспознанное 9X_openjdk имя» в подтверждении связи SSL, которое 9X_.java игнорируется большинством клиентов ... за 9X_tls исключением Java. Как упомянул @Bob Kerns, инженеры 9X_jre Oracle отказываются «исправлять» эту ошибку 9X_java / функцию.
В качестве обходного пути они 9X_oraclejdk предлагают установить свойство jsse.enableSNIExtension
. Чтобы ваши 9X_javax программы работали без повторной компиляции, запустите 9X_java-se приложение как:
java -Djsse.enableSNIExtension=false yourClass
Свойство также можно задать 9X_javax в коде Java, но оно должно быть установлено 9X_javax перед любыми действиями SSL. После загрузки библиотеки SSL вы можете 9X_jre изменить свойство, но это won't have any effect on the SNI status. Чтобы отключить 9X_java-se SNI во время выполнения (с указанными выше 9X_openjdk ограничениями), используйте:
System.setProperty("jsse.enableSNIExtension", "false");
Недостатком 9X_jdk установки этого флага является то, что SNI 9X_javax отключен везде в приложении. Чтобы использовать 9X_j2se SNI и по-прежнему поддерживать неправильно 9X_j2se настроенные серверы:
- Создайте
SSLSocket
с именем хоста, к которому вы хотите подключиться. Назовем этоsslsock
. - Попробуйте запустить
sslsock.startHandshake()
. Это будет заблокировано до тех пор, пока это не будет выполнено, или сгенерирует исключение в случае ошибки. При возникновении ошибки вstartHandshake()
получите сообщение об исключении. Если он равенhandshake alert: unrecognized_name
, значит, вы обнаружили неверно настроенный сервер. - Когда вы получили предупреждение
unrecognized_name
(фатальное в Java), попробуйте снова открытьSSLSocket
, но на этот раз без имени хоста. Это фактически отключает SNI (в конце концов, расширение SNI предназначено для добавления имени хоста в сообщение ClientHello).
Для SSL-прокси Webscarab 9X_tls this commit реализует настройку отката.
- Для тех, кто интересуется Java 8, Oracle все еще не изменил поведение и по-прежнему требует от программиста ловить ...
Ответ #2
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
У меня была, как мне кажется, та же проблема. Я 9X_jre обнаружил, что мне нужно настроить конфигурацию 9X_core-java Apache, чтобы включить ServerName или ServerAlias 9X_.java для хоста.
Ошибка этого кода:
public class a { public static void main(String [] a) throws Exception { java.net.URLConnection c = new java.net.URL("https://mydomain.com/").openConnection(); c.setDoOutput(true); c.getOutputStream(); } }
И этот код 9X_j2se сработал:
public class a { public static void main(String [] a) throws Exception { java.net.URLConnection c = new java.net.URL("https://google.com/").openConnection(); c.setDoOutput(true); c.getOutputStream(); } }
Wireshark обнаружил, что во время 9X_oraclejdk приветствия TSL / SSL предупреждение Предупреждение 9X_core-java (уровень: предупреждение, описание: нераспознанное 9X_java-api имя), приветствие сервера Отправлялся с 9X_javax сервера клиенту. Это было всего лишь предупреждением, однако 9X_jre Java 7.1 немедленно ответила «Fatal, Description: Unexpected 9X_.java Message», что, как я полагаю, означает, что 9X_oraclejdk библиотеки Java SSL не хотят видеть предупреждение 9X_core-java о нераспознанном имени.
Из вики по безопасности 9X_java транспортного уровня (TLS):
112 Предупреждение 9X_j2se о нераспознанном имени Только TLS; В индикаторе 9X_java-se имени сервера клиента указано имя хоста, не 9X_.java поддерживаемое сервером
Это заставило меня 9X_java-api взглянуть на мои файлы конфигурации Apache, и 9X_oraclejdk я обнаружил, что если я добавил ServerName 9X_java-api или ServerAlias для имени, отправленного 9X_oraclejdk со стороны клиента / java, он работал правильно 9X_java без каких-либо ошибок.
ServerName mydomain.com ServerAlias www.mydomain.com
- Это сработало и для меня. (сработало бы лучше, е ...
Ответ #3
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Вы можете отключить отправку записей SNI 9X_openjdk с помощью системного свойства jsse.enableSNIExtension 9X_ssl = false.
Если вы можете изменить код, это 9X_tls поможет использовать SSLCocketFactory#createSocket()
(без параметра хоста 9X_java-libraries или с подключенным сокетом). В этом случае 9X_javax он не будет отправлять указание server_name.
- У меня работает с `-Djsse.enableSNIExtension = false`. Но что еще он делает? Вредно ли это для остальной части ...
Ответ #4
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Мы также столкнулись с этой ошибкой при 9X_oraclejdk новой сборке сервера Apache.
Исправление 9X_openjdk в нашем случае заключалось в том, чтобы 9X_jre определить ServerAlias
в httpd.conf
, который соответствовал имени 9X_core-java хоста, к которому Java пыталась подключиться. Наш 9X_tls ServerName
был установлен на внутреннее имя хоста. В 9X_oraclejdk нашем сертификате SSL использовалось имя 9X_tls внешнего хоста, но этого было недостаточно, чтобы 9X_java избежать предупреждения.
Для облегчения отладки 9X_jdk вы можете использовать эту команду ssl:
openssl s_client -servername -connect :443 -state
Если 9X_ssl есть проблема с этим именем хоста, он напечатает 9X_java-api это сообщение в верхней части вывода:
SSL3 alert read: warning:unrecognized name
Следует 9X_openjdk также отметить, что мы не получали эту ошибку 9X_ssl при использовании этой команды для подключения 9X_java-libraries к внутреннему имени хоста, даже если оно 9X_java-libraries не соответствовало сертификату SSL.
- Благодарим за включение примера о том, к ...
Ответ #5
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Вместо того, чтобы полагаться на механизм 9X_java виртуального хоста по умолчанию в apache, вы 9X_tls можете определить один последний общий виртуальный 9X_.java хост, который использует произвольное имя 9X_java-se сервера и подстановочный знак ServerAlias, например
ServerName catchall.mydomain.com ServerAlias *.mydomain.com
Таким 9X_oraclejdk образом вы можете использовать SNI, и apache 9X_jdk не будет отправлять обратно предупреждение 9X_java SSL.
Конечно, это работает, только если вы 9X_java-se можете легко описать все свои домены, используя 9X_java-se синтаксис с подстановочными знаками.
Ответ #6
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Это должно быть полезно. Чтобы повторить 9X_jdk попытку при ошибке SNI в Apache HttpClient 9X_j2se 4.4 - самый простой способ, который мы придумали 9X_java (см. HTTPCLIENT-1522):
public class SniHttpClientConnectionOperator extends DefaultHttpClientConnectionOperator { public SniHttpClientConnectionOperator(Lookup socketFactoryRegistry) { super(socketFactoryRegistry, null, null); } @Override public void connect( final ManagedHttpClientConnection conn, final HttpHost host, final InetSocketAddress localAddress, final int connectTimeout, final SocketConfig socketConfig, final HttpContext context) throws IOException { try { super.connect(conn, host, localAddress, connectTimeout, socketConfig, context); } catch (SSLProtocolException e) { Boolean enableSniValue = (Boolean) context.getAttribute(SniSSLSocketFactory.ENABLE_SNI); boolean enableSni = enableSniValue == null || enableSniValue; if (enableSni && e.getMessage() != null && e.getMessage().equals("handshake alert: unrecognized_name")) { TimesLoggers.httpworker.warn("Server received saw wrong SNI host, retrying without SNI"); context.setAttribute(SniSSLSocketFactory.ENABLE_SNI, false); super.connect(conn, host, localAddress, connectTimeout, socketConfig, context); } else { throw e; } } } }
и
public class SniSSLSocketFactory extends SSLConnectionSocketFactory { public static final String ENABLE_SNI = "__enable_sni__"; /* * Implement any constructor you need for your particular application - * SSLConnectionSocketFactory has many variants */ public SniSSLSocketFactory(final SSLContext sslContext, final HostnameVerifier verifier) { super(sslContext, verifier); } @Override public Socket createLayeredSocket( final Socket socket, final String target, final int port, final HttpContext context) throws IOException { Boolean enableSniValue = (Boolean) context.getAttribute(ENABLE_SNI); boolean enableSni = enableSniValue == null || enableSniValue; return super.createLayeredSocket(socket, enableSni ? target : "", port, context); } }
и
cm = new PoolingHttpClientConnectionManager(new SniHttpClientConnectionOperator(socketFactoryRegistry), null, -1, TimeUnit.MILLISECONDS);
- Это было именно то, что я искал, большое вам спасибо! Я не нашел другого способа поддержки SNI и серверов, которые одновременно отвеч ...
Ответ #7
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Использование:
- System.setProperty ("jsse.enableSNIExtension", "false");
- Перезагрузите Tomcat (важно)
9X_ssl
Ответ #8
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
К сожалению, вы не можете предоставить системные 9X_core-java свойства инструменту jarsigner.exe.
Я отправил 9X_java-se дефект 7177232, сославшись на дефект @eckes 7127374 и 9X_core-java объяснив, почему он был закрыт по ошибке.
Мой 9X_tls дефект связан с воздействием на инструмент 9X_tls jarsigner, но, возможно, он приведет к повторному 9X_java открытию другого дефекта и правильному решению 9X_java-libraries проблемы.
ОБНОВЛЕНИЕ: На самом деле оказывается, что 9X_openjdk вы МОЖЕТЕ предоставить системные свойства 9X_.java инструменту Jarsigner, но этого просто нет 9X_core-java в справочном сообщении. Используйте jarsigner -J-Djsse.enableSNIExtension=false
- Спасибо Бобу за ответ. К сожалению, Oracle все еще не понимает всего этого. Предупреждение SNI не является фатальным, его можно рассматривать как фатальный. Но большинство типичных клиентов SSL (то есть браузеров) ...
Ответ #9
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Разберитесь с этой проблемой с помощью весенней загрузки и 9X_ssl jvm 1.7 и 1.8. В AWS у нас не было возможности 9X_tls изменить ServerName и ServerAlias на совпадение 9X_j2se (они разные), поэтому мы сделали следующее:
В 9X_java-libraries build.gradle мы добавили следующее:
System.setProperty("jsse.enableSNIExtension", "false") bootRun.systemProperties = System.properties
Это позволило нам 9X_java-libraries обойти проблему с «Нераспознанным именем».
Ответ #10
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Я столкнулся с той же проблемой, и оказалось, что 9X_tls обратный DNS был настроен неправильно, он 9X_j2se указывал на неправильное имя хоста для IP. После 9X_j2se того, как я исправлю обратный DNS и перезапущу 9X_j2se httpd, предупреждение исчезнет. (если я 9X_java-api не исправляю обратный DNS, добавление ServerName 9X_java-api тоже помогло мне)
Ответ #11
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Мой VirtualHost
ServerName
был закомментирован по умолчанию. Это 9X_java-api сработало после раскомментирования.
Ответ #12
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Если вы создаете клиент с Resttemplate, вы 9X_core-java можете установить конечную точку только 9X_java-libraries следующим образом: https://IP/path_to_service и установить requestFactory.
С 9X_javax помощью этого решения вам не нужно перезапускать 9X_j2se TOMCAT или Apache:
public static HttpComponentsClientHttpRequestFactory requestFactory(CloseableHttpClient httpClient) { TrustStrategy acceptingTrustStrategy = new TrustStrategy() { @Override public boolean isTrusted(X509Certificate[] chain, String authType) throws CertificateException { return true; } }; SSLContext sslContext = null; try { sslContext = org.apache.http.ssl.SSLContexts.custom() .loadTrustMaterial(null, acceptingTrustStrategy) .build(); } catch (Exception e) { logger.error(e.getMessage(), e); } HostnameVerifier hostnameVerifier = new HostnameVerifier() { @Override public boolean verify(String hostname, SSLSession session) { return true; } }; final SSLConnectionSocketFactory csf = new SSLConnectionSocketFactory(sslContext,hostnameVerifier); final Registry registry = RegistryBuilder.create() .register("http", new PlainConnectionSocketFactory()) .register("https", csf) .build(); final PoolingHttpClientConnectionManager cm = new PoolingHttpClientConnectionManager(registry); cm.setMaxTotal(100); httpClient = HttpClients.custom() .setSSLSocketFactory(csf) .setConnectionManager(cm) .build(); HttpComponentsClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory(); requestFactory.setHttpClient(httpClient); return requestFactory; }
Ответ #13
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Я также столкнулся с этой проблемой при 9X_javax обновлении Java 1.6_29 до 1.7.
К сожалению, мой 9X_java-api клиент обнаружил настройку в панели управления 9X_javax Java, которая решает эту проблему.
На вкладке 9X_oraclejdk "Дополнительно" установите флажок "Использовать 9X_core-java формат ClientHello, совместимый с SSL 2.0".
Кажется, проблема 9X_javax решена.
Мы используем Java-апплеты в браузере 9X_openjdk Internet Explorer.
Надеюсь, это поможет.
Ответ #14
Ответ на вопрос: Предупреждение о подтверждении связи SSL: ошибка unrecognized_name с момента обновления до Java 1.7.0
Вот решение для Appache httpclient 4.5.11. У 9X_j2se меня возникла проблема с сертификатом, который 9X_java-se имеет подстановочный знак *.hostname.com
. Он вернул мне 9X_java-libraries то же исключение, но я не должен использовать 9X_javax отключение по свойству System.setProperty("jsse.enableSNIExtension", "false");
, потому что это 9X_.java привело к ошибке в клиенте местоположения 9X_core-java Google.
Я нашел простое решение (только модифицируя 9X_core-java сокет):
import io.micronaut.context.annotation.Bean; import io.micronaut.context.annotation.Factory; import org.apache.http.client.HttpClient; import org.apache.http.conn.ssl.NoopHostnameVerifier; import org.apache.http.conn.ssl.SSLConnectionSocketFactory; import org.apache.http.impl.client.HttpClients; import org.apache.http.ssl.SSLContexts; import javax.inject.Named; import javax.net.ssl.SSLParameters; import javax.net.ssl.SSLSocket; import java.io.IOException; import java.util.List; @Factory public class BeanFactory { @Bean @Named("without_verify") public HttpClient provideHttpClient() { SSLConnectionSocketFactory connectionSocketFactory = new SSLConnectionSocketFactory(SSLContexts.createDefault(), NoopHostnameVerifier.INSTANCE) { @Override protected void prepareSocket(SSLSocket socket) throws IOException { SSLParameters parameters = socket.getSSLParameters(); parameters.setServerNames(List.of()); socket.setSSLParameters(parameters); super.prepareSocket(socket); } }; return HttpClients.custom() .setSSLSocketFactory(connectionSocketFactory) .build(); } }
-
9
-
7
-
7
-
2
-
6
-
5
-
8
-
14
-
2
-
10
-
2
-
4
-
8
-
2
-
4
-
4
-
12
-
5
-
5
-
11
-
5
-
4
-
6
-
7
-
3
-
15
-
20
-
6
-
12
-
16
-
7
-
4
-
2
-
7
-
6
-
2
-
5
-
3
-
8
-
4
-
1
-
2
-
3
-
1
-
6
-
9
-
3
-
3
-
4
-
16