curl / libcurl / API / curl_easy_setopt / CURLOPT_LOCALPORT

CURLOPT_LOCALPORT explained

Name

CURLOPT_LOCALPORT - local port number to use for socket

Synopsis

#include <curl/curl.h>
 
CURLcode curl_easy_setopt(CURL *handle, CURLOPT_LOCALPORT, long port);

Description

Pass a long. This sets the local port number of the socket used for the connection. This can be used in combination with CURLOPT_INTERFACE and you are recommended to use CURLOPT_LOCALPORTRANGE as well when this option is set. Valid port numbers are 1 - 65535.

Default

0, disabled - use whatever the system thinks is fine

Protocols

All

Example

int main(void)
{
  CURL *curl = curl_easy_init();
  if(curl) {
    CURLcode res;
    curl_easy_setopt(curl, CURLOPT_URL, "https://example.com/foo.bin");
    curl_easy_setopt(curl, CURLOPT_LOCALPORT, 49152L);
    /* and try 20 more ports following that */
    curl_easy_setopt(curl, CURLOPT_LOCALPORTRANGE, 20L);
    res = curl_easy_perform(curl);
    curl_easy_cleanup(curl);
  }
}

Availability

Added in 7.15.2

Return value

Returns CURLE_OK

See also

CURLINFO_LOCAL_PORT(3), CURLOPT_INTERFACE(3), CURLOPT_LOCALPORTRANGE(3)

This HTML page was made with roffit.