HttpClient.Version (gb.net.curl)
Property Version As Integer
Return or set the HTTP protocol version to use.
It can be one of the following constants:
HttpVersionNone
|
We do not care about what version the library uses. libcurl uses whatever it thinks fit.
|
HttpVersion10
|
Enforce HTTP 1.0 requests.
|
HttpVersion11
|
Enforce HTTP 1.1 requests.
|
HttpVersion20
|
Attempt HTTP 2 requests. libcurl falls back to HTTP 1.1 if HTTP 2 cannot be negotiated with the server. (Added in 7.33.0)
When libcurl uses HTTP/2 over HTTPS, it does not itself insist on TLS 1.2 or higher even though that is required by the specification.
A user can add this version requirement with CURLOPT_SSLVERSION.
|
HttpVersion2Tls
|
Attempt HTTP 2 over TLS (HTTPS) only. libcurl falls back to HTTP 1.1 if HTTP 2 cannot be negotiated with the HTTPS server. For clear text HTTP servers, libcurl uses 1.1. (Added in 7.47.0)
|
HttpVersion2PriorKnowledge
|
Issue non-TLS HTTP requests using HTTP/2 without HTTP/1.1 Upgrade. It requires prior knowledge that the server supports HTTP/2 straight away. HTTPS requests still do HTTP/2 the standard way with negotiated protocol version in the TLS handshake. (Added in 7.49.0)
Since 8.10.0 if this option is set for an HTTPS request then the application layer protocol version (ALPN) offered to the server is only HTTP/2. Prior to that both HTTP/1.1 and HTTP/2 were offered.
|
HttpVersion3
|
(Added in 7.66.0) This option makes libcurl attempt to use HTTP/3 to the host given in the URL, with fallback to earlier HTTP versions if needed.
|
HttpVersion3Only
|
(Added in 7.88.0) Setting this makes libcurl attempt to use HTTP/3 directly to server given in the URL and does not downgrade to earlier HTTP version if the server does not support HTTP/3.
|