[ 
https://issues.apache.org/jira/browse/HTTPCORE-728?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17632198#comment-17632198
 ] 

Eric Hubert commented on HTTPCORE-728:
--------------------------------------

Based on the release notes, I'd expect this to be something known:
"Please note that 5.2 upgrades the minimal JRE level to version 8 (8u251 is 
required)."

> SSLIOSession uses SSLEngine.getApplicationProtocol() which doesn't exist in 
> all Java 8 versions
> -----------------------------------------------------------------------------------------------
>
>                 Key: HTTPCORE-728
>                 URL: https://issues.apache.org/jira/browse/HTTPCORE-728
>             Project: HttpComponents HttpCore
>          Issue Type: Bug
>          Components: HttpCore
>    Affects Versions: 5.2
>            Reporter: Rob Spoor
>            Priority: Major
>
> We have a Renovate bot that upgraded the HttpClient version from 5.1.3 to 
> 5.2. Tests that were working before now started failing with the following 
> message:
> {code}Exception in thread "I/O server dispatch-1" 
> java.lang.NoSuchMethodError: 
> javax.net.ssl.SSLEngine.getApplicationProtocol()Ljava/lang/String;
>       at 
> org.apache.hc.core5.reactor.ssl.SSLIOSession.doHandshake(SSLIOSession.java:429){code}
> I've done a comparison between version 5.1.3 and 5.2, and this change is 
> causing the issue:
> 5.1.3:
> {code}final String applicationProtocol = 
> ReflectionUtils.callGetter(this.sslEngine, "ApplicationProtocol", 
> String.class);{code}
> 5.2:
> {code}final String applicationProtocol = 
> this.sslEngine.getApplicationProtocol();{code}
> The cause of the issue is that this method is officially added in Java 9. 
> From 
> https://docs.oracle.com/en/java/javase/19/docs/api/java.base/javax/net/ssl/SSLEngine.html#getApplicationProtocol():
> {quote}Since:
> 9{quote}
> It seems that this method is backported to Java 8, but not to *all* versions. 
> From 
> https://docs.oracle.com/javase/8/docs/api/javax/net/ssl/SSLEngine.html#getApplicationProtocol--:
> {quote}API Note:
> This method is defined in Java SE 8 Maintenance Release 3.{quote}
> One solution could be to make users upgrade Java 8 to the latest version (our 
> build server currently uses version 1.8.0_221). However, that may not work 
> for everybody.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to