Change in closeOutbound() behavior for unused SSLEngine

Xuelei Fan xuelei.fan at oracle.com
Wed Oct 16 15:42:26 UTC 2019


The TLS protocol was changed to use half-close policy since TLS 1.3.  As 
means that sslEngine.closeOutbound() will close the outbound and keep 
the inbound open.  "NEED_UNWRAP" is used to indicate that the engine can 
still be used to decode input message.

For the specific case bellow, it is reasonable to expect 
"NOT_HANDSHAKING" as the handshaking has not been started.  On the other 
side, as only the inbound open, it is also reasonable to me to use 
"NEED_UNWRAP" although there is nothing to unwrap.  I think, using 
""NOT_HANDSHAKING" may lead to confusing about what the next operation, 
wrap() or unwrap(), could be in practice.  CLOSED is not an option to me 
as the inbound is still open.

I understand there might be some compatibility issues for the use of 
half-close policy.  I may close both inbound and outbound of an engine 
in the application code if the connection is not used.

Is there a known compatibility impact on you applications?

Thanks & Regards,
Xuelei

On 10/16/2019 2:53 AM, Simone Bordet wrote:
> Hi,
> 
> SSLContext sslContext = SSLContext.getDefault();
> SSLEngine sslEngine = sslContext.createSSLEngine();
> sslEngine.closeOutbound();
> SSLEngineResult.HandshakeStatus hsStatus = sslEngine.getHandshakeStatus();
> System.err.println("hsStatus = " + hsStatus);
> 
> This prints "NOT_HANDSHAKING" in Java 8 and "NEED_UNWRAP" in JDK 11+.
> 
> In both cases, trying to wrap() consumes and produces 0 bytes (so the
> close_notify is not generated, which I think is fine given that the
> SSLEngine was never used) and produces a CLOSED result.
> 
> This case is common for connections that are established but never
> used (not even a TLS byte was exchanged).
> 
> Is this change in behavior expected?
> 
> I find strange that calling closeOutbound() results in a NEED_UNWRAP
> (as there is nothing to read).
> 
> Thanks!
> 



More information about the security-dev mailing list