|  | Home | Libraries | People | FAQ | More | 
        A secure SSL/TLS connection requires a proper shutdown process to securely
        indicate the EOF
        condition. This process prevents a type of attack known as a truncation
        attack in which an attacker can close the underlying transport
        layer and control the length of the last message in the SSL/TLS connection.
        A shutdown process consists of exchanging close_notify
        message between two parties. In Boost.Asio
        these steps happen by calling shutdown() or async_shutdown() on ssl::stream
        object.
      
There are SSL/TLS implementations that don't perform a proper shutdown process and simply close the underlying transport layer instead. As a result, the EOF condition in these applications is not cryptographically secure and should not be relied upon. However, there are scenarios where an HTTPS client or server doesn't need EOF for determining the end of the last message:
Content-Length
              header, and the body is fully received (a known body length).
            
          In such scenarios, http::read
          or http::async_read operations succeed as they
          don't need EOF to complete. However, the next operation on the stream would
          fail with an net::ssl::error::stream_truncated error.
        
For example, let's assume we are using Beast for communicating with an HTTPS server that doesn't perform a proper SSL/TLS shutdown:
// Receive the HTTP response http::read(stream, buffer, res); // Gracefully shutdown the SSL/TLS connection error_code ec; stream.shutdown(ec); // Non-compliant servers don't participate in the SSL/TLS shutdown process and // close the underlying transport layer. This causes the shutdown operation to // complete with a `stream_truncated` error. One might decide not to log such // errors as there are many non-compliant servers in the wild. if(ec != net::ssl::error::stream_truncated) log(ec);
This is a rare case and indeed a security issue when HTTPS servers don't perform a proper SSL/TLS shutdown procedure and send an HTTP response message that relies on EOF to determine the end of the body. This is a security concern because without an SSL/TLS shutdown procedure, the EOF is not cryptographically secure, leaving the message body vulnerable to truncation attacks.
The following is an example that can read an HTTP response from such a server:
// Use an HTTP response parser to have more control http::response_parser<http::dynamic_body> parser; error_code ec; // Receive the HTTP response until the end or until an error occurs http::read(stream, buffer, parser, ec); // Try to manually commit the EOF, the resulting message body would be // vulnerable to truncation attacks. if(parser.need_eof() && ec == net::ssl::error::stream_truncated) parser.put_eof(ec); // Override the error_code if(ec) throw system_error{ec}; // Access the HTTP response inside the parser std::cout << parser.get() << std::endl; // Gracefully shutdown the SSL/TLS connection stream.shutdown(ec); // Override the error_code // Non-compliant servers don't participate in the SSL/TLS shutdown process and // close the underlying transport layer. This causes the shutdown operation to // complete with a `stream_truncated` error. One might decide not to log such // errors as there are many non-compliant servers in the wild. if(ec != net::ssl::error::stream_truncated) log(ec);