remote_port used in Host: headers only when non-default

This commit is contained in:
Daniel Stenberg
2000-10-20 13:48:38 +00:00
parent 135cc036aa
commit c44b10de41
2 changed files with 10 additions and 3 deletions

View File

@@ -336,6 +336,12 @@ CURLcode http(struct connectdata *conn)
} }
if(!checkheaders(data, "Host:")) { if(!checkheaders(data, "Host:")) {
if(((conn->protocol&PROT_HTTPS) && (data->remote_port == PORT_HTTPS)) ||
(!(conn->protocol&PROT_HTTPS) && (data->remote_port == PORT_HTTP)) )
/* If (HTTPS on port 443) OR (non-HTTPS on port 80) then don't include
the port number in the host string */
data->ptr_host = maprintf("Host: %s\r\n", host);
else
data->ptr_host = maprintf("Host: %s:%d\r\n", host, data->remote_port); data->ptr_host = maprintf("Host: %s:%d\r\n", host, data->remote_port);
} }

View File

@@ -961,7 +961,7 @@ CURLcode curl_connect(CURL *curl, CURLconnect **in_connect)
conn->curl_close = http_close; conn->curl_close = http_close;
#else /* USE_SSLEAY */ #else /* USE_SSLEAY */
failf(data, "SSL is disabled, https: not supported!"); failf(data, "libcurl was built with SSL disabled, https: not supported!");
return CURLE_UNSUPPORTED_PROTOCOL; return CURLE_UNSUPPORTED_PROTOCOL;
#endif /* !USE_SSLEAY */ #endif /* !USE_SSLEAY */
} }
@@ -1137,6 +1137,7 @@ CURLcode curl_connect(CURL *curl, CURLconnect **in_connect)
*tmp++ = '\0'; *tmp++ = '\0';
data->port = atoi(tmp); data->port = atoi(tmp);
} }
data->remote_port = data->port; /* it is the same port */
/* Connect to target host right on */ /* Connect to target host right on */
conn->hp = GetHost(data, conn->name, &conn->hostent_buf); conn->hp = GetHost(data, conn->name, &conn->hostent_buf);