curl_easy_setopt - set options for a curl easy handle
Name
curl_easy_setopt - set options for a curl easy handle
Synopsis
#include <curl/curl.h> CURLcode curl_easy_setopt(CURL *handle, CURLoption option, parameter);
Description
curl_easy_setopt is used to tell libcurl how to behave. By setting the appropriate options, the application can change libcurl's behavior. All options are set with an option followed by a parameter. That parameter can be a long, a function pointer, an object pointer or a curl_off_t, depending on what the specific option expects. Read this manual carefully as bad input values may cause libcurl to behave badly! You can only set one option in each function call. A typical application uses many curl_easy_setopt calls in the setup phase.
Options set with this function call are valid for all forthcoming transfers performed using this handle. The options are not in any way reset between transfers, so if you want subsequent transfers with different options, you must change them between the transfers. You can optionally reset all options back to internal default with curl_easy_reset.
Strings passed to libcurl as 'char *' arguments, are copied by the library; the string storage associated to the pointer argument may be discarded or reused after curl_easy_setopt returns. The only exception to this rule is really CURLOPT_POSTFIELDS, but the alternative that copies the string CURLOPT_COPYPOSTFIELDS has some usage characteristics you need to read up on. This function does not accept input strings longer than CURL_MAX_INPUT_LENGTH (8 MB).
The order in which the options are set does not matter.
Before version 7.17.0, strings were not copied. Instead the user was forced keep them available until libcurl no longer needed them.
The handle is the return code from a curl_easy_init or curl_easy_duphandle call.
Behavior options
Display verbose information. See CURLOPT_VERBOSE
Include the header in the body output. See CURLOPT_HEADER
Shut off the progress meter. See CURLOPT_NOPROGRESS
Do not install signal handlers. See CURLOPT_NOSIGNAL
Transfer multiple files according to a filename pattern. See CURLOPT_WILDCARDMATCH
Callback options
Callback for writing data. See CURLOPT_WRITEFUNCTION
Data pointer to pass to the write callback. See CURLOPT_WRITEDATA
Callback for reading data. See CURLOPT_READFUNCTION
Data pointer to pass to the read callback. See CURLOPT_READDATA
Deprecated option Callback for I/O operations. See CURLOPT_IOCTLFUNCTION
Deprecated option Data pointer to pass to the I/O callback. See CURLOPT_IOCTLDATA
Callback for seek operations. See CURLOPT_SEEKFUNCTION
Data pointer to pass to the seek callback. See CURLOPT_SEEKDATA
Callback for sockopt operations. See CURLOPT_SOCKOPTFUNCTION
Data pointer to pass to the sockopt callback. See CURLOPT_SOCKOPTDATA
Callback for socket creation. See CURLOPT_OPENSOCKETFUNCTION
Data pointer to pass to the open socket callback. See CURLOPT_OPENSOCKETDATA
Callback for closing socket. See CURLOPT_CLOSESOCKETFUNCTION
Data pointer to pass to the close socket callback. See CURLOPT_CLOSESOCKETDATA
OBSOLETE callback for progress meter. See CURLOPT_PROGRESSFUNCTION
Data pointer to pass to the progress meter callback. See CURLOPT_PROGRESSDATA
Callback for progress meter. See CURLOPT_XFERINFOFUNCTION
Data pointer to pass to the progress meter callback. See CURLOPT_XFERINFODATA
Callback for writing received headers. See CURLOPT_HEADERFUNCTION
Data pointer to pass to the header callback. See CURLOPT_HEADERDATA
Callback for debug information. See CURLOPT_DEBUGFUNCTION
Data pointer to pass to the debug callback. See CURLOPT_DEBUGDATA
Callback for SSL context logic. See CURLOPT_SSL_CTX_FUNCTION
Data pointer to pass to the SSL context callback. See CURLOPT_SSL_CTX_DATA
CURLOPT_CONV_TO_NETWORK_FUNCTION
OBSOLETE Callback for code base conversion. See CURLOPT_CONV_TO_NETWORK_FUNCTION
CURLOPT_CONV_FROM_NETWORK_FUNCTION
OBSOLETE Callback for code base conversion. See CURLOPT_CONV_FROM_NETWORK_FUNCTION
CURLOPT_CONV_FROM_UTF8_FUNCTION
OBSOLETE Callback for code base conversion. See CURLOPT_CONV_FROM_UTF8_FUNCTION
Callback for RTSP interleaved data. See CURLOPT_INTERLEAVEFUNCTION
Data pointer to pass to the RTSP interleave callback. See CURLOPT_INTERLEAVEDATA
Callback for wildcard download start of chunk. See CURLOPT_CHUNK_BGN_FUNCTION
Callback for wildcard download end of chunk. See CURLOPT_CHUNK_END_FUNCTION
Data pointer to pass to the chunk callbacks. See CURLOPT_CHUNK_DATA
Callback for wildcard matching. See CURLOPT_FNMATCH_FUNCTION
Data pointer to pass to the wildcard matching callback. See CURLOPT_FNMATCH_DATA
CURLOPT_SUPPRESS_CONNECT_HEADERS
Suppress proxy CONNECT response headers from user callbacks. See CURLOPT_SUPPRESS_CONNECT_HEADERS
CURLOPT_RESOLVER_START_FUNCTION
Callback to be called before a new resolve request is started. See CURLOPT_RESOLVER_START_FUNCTION
Data pointer to pass to resolver start callback. See CURLOPT_RESOLVER_START_DATA
Callback to be called after a connection is established but before a request is made on that connection. See CURLOPT_PREREQFUNCTION
Data pointer to pass to the CURLOPT_PREREQFUNCTION callback. See CURLOPT_PREREQDATA
Error options
Error message buffer. See CURLOPT_ERRORBUFFER
stderr replacement stream. See CURLOPT_STDERR
Fail on HTTP 4xx errors. CURLOPT_FAILONERROR
Keep sending on HTTP >= 300 errors. CURLOPT_KEEP_SENDING_ON_ERROR
Network options
URL to work on. See CURLOPT_URL
Disable squashing /../ and /./ sequences in the path. See CURLOPT_PATH_AS_IS
Deprecated option Allowed protocols. See CURLOPT_PROTOCOLS
Allowed protocols. See CURLOPT_PROTOCOLS_STR
Deprecated option Protocols to allow redirects to. See CURLOPT_REDIR_PROTOCOLS
Protocols to allow redirects to. See CURLOPT_REDIR_PROTOCOLS_STR
Default protocol. See CURLOPT_DEFAULT_PROTOCOL
Proxy to use. See CURLOPT_PROXY
Socks proxy to use. See CURLOPT_PRE_PROXY
Proxy port to use. See CURLOPT_PROXYPORT
Proxy type. See CURLOPT_PROXYTYPE
Filter out hosts from proxy use. CURLOPT_NOPROXY
Tunnel through the HTTP proxy. CURLOPT_HTTPPROXYTUNNEL
Connect to a specific host and port. See CURLOPT_CONNECT_TO
Socks5 authentication methods. See CURLOPT_SOCKS5_AUTH
Deprecated option Socks5 GSSAPI service name. See CURLOPT_SOCKS5_GSSAPI_SERVICE
Socks5 GSSAPI NEC mode. See CURLOPT_SOCKS5_GSSAPI_NEC
Proxy authentication service name. CURLOPT_PROXY_SERVICE_NAME
Send an HAProxy PROXY protocol v1 header. See CURLOPT_HAPROXYPROTOCOL
Spoof the client IP in an HAProxy PROXY protocol v1 header. See CURLOPT_HAPROXY_CLIENT_IP
Authentication service name. CURLOPT_SERVICE_NAME
Bind connection locally to this. See CURLOPT_INTERFACE
Bind connection locally to this port. See CURLOPT_LOCALPORT
Bind connection locally to port range. See CURLOPT_LOCALPORTRANGE
Timeout for DNS cache. See CURLOPT_DNS_CACHE_TIMEOUT
OBSOLETE Enable global DNS cache. See CURLOPT_DNS_USE_GLOBAL_CACHE
Use this DoH server for name resolves. See CURLOPT_DOH_URL
Ask for alternate buffer size. See CURLOPT_BUFFERSIZE
Port number to connect to. See CURLOPT_PORT
Enable TCP Fast Open. See CURLOPT_TCP_FASTOPEN
Disable the Nagle algorithm. See CURLOPT_TCP_NODELAY
IPv6 scope for local addresses. See CURLOPT_ADDRESS_SCOPE
Enable TCP keep-alive. See CURLOPT_TCP_KEEPALIVE
Idle time before sending keep-alive. See CURLOPT_TCP_KEEPIDLE
Interval between keep-alive probes. See CURLOPT_TCP_KEEPINTVL
Path to a Unix domain socket. See CURLOPT_UNIX_SOCKET_PATH
Path to an abstract Unix domain socket. See CURLOPT_ABSTRACT_UNIX_SOCKET
Names and passwords options (authentication)
Enable .netrc parsing. See CURLOPT_NETRC
.netrc filename. See CURLOPT_NETRC_FILE
Username and password. See CURLOPT_USERPWD
Proxy username and password. See CURLOPT_PROXYUSERPWD
Username. See CURLOPT_USERNAME
Password. See CURLOPT_PASSWORD
Login options. See CURLOPT_LOGIN_OPTIONS
Proxy username. See CURLOPT_PROXYUSERNAME
Proxy password. See CURLOPT_PROXYPASSWORD
HTTP server authentication methods. See CURLOPT_HTTPAUTH
TLS authentication username. See CURLOPT_TLSAUTH_USERNAME
CURLOPT_PROXY_TLSAUTH_USERNAME
Proxy TLS authentication username. See CURLOPT_PROXY_TLSAUTH_USERNAME
TLS authentication password. See CURLOPT_TLSAUTH_PASSWORD
CURLOPT_PROXY_TLSAUTH_PASSWORD
Proxy TLS authentication password. See CURLOPT_PROXY_TLSAUTH_PASSWORD
TLS authentication methods. See CURLOPT_TLSAUTH_TYPE
Proxy TLS authentication methods. See CURLOPT_PROXY_TLSAUTH_TYPE
HTTP proxy authentication methods. See CURLOPT_PROXYAUTH
SASL authorization identity (identity to act as). See CURLOPT_SASL_AUTHZID
Enable SASL initial response. See CURLOPT_SASL_IR
OAuth2 bearer token. See CURLOPT_XOAUTH2_BEARER
CURLOPT_DISALLOW_USERNAME_IN_URL
Do not allow username in URL. See CURLOPT_DISALLOW_USERNAME_IN_URL
Http options
Automatically set Referer: header. See CURLOPT_AUTOREFERER
Accept-Encoding and automatic decompressing data. See CURLOPT_ACCEPT_ENCODING
Request Transfer-Encoding. See CURLOPT_TRANSFER_ENCODING
Follow HTTP redirects. See CURLOPT_FOLLOWLOCATION
Do not restrict authentication to original host. CURLOPT_UNRESTRICTED_AUTH
Maximum number of redirects to follow. See CURLOPT_MAXREDIRS
How to act on redirects after POST. See CURLOPT_POSTREDIR
Deprecated option Issue an HTTP PUT request. See CURLOPT_PUT
Issue an HTTP POST request. See CURLOPT_POST
Send a POST with this data. See CURLOPT_POSTFIELDS
The POST data is this big. See CURLOPT_POSTFIELDSIZE
The POST data is this big. See CURLOPT_POSTFIELDSIZE_LARGE
Send a POST with this data - and copy it. See CURLOPT_COPYPOSTFIELDS
Deprecated option Multipart formpost HTTP POST. See CURLOPT_HTTPPOST
Referer: header. See CURLOPT_REFERER
User-Agent: header. See CURLOPT_USERAGENT
Custom HTTP headers. See CURLOPT_HTTPHEADER
Control custom headers. See CURLOPT_HEADEROPT
Custom HTTP headers sent to proxy. See CURLOPT_PROXYHEADER
Alternative versions of 200 OK. See CURLOPT_HTTP200ALIASES
Cookie(s) to send. See CURLOPT_COOKIE
File to read cookies from. See CURLOPT_COOKIEFILE
File to write cookies to. See CURLOPT_COOKIEJAR
Start a new cookie session. See CURLOPT_COOKIESESSION
Add or control cookies. See CURLOPT_COOKIELIST
Specify the Alt-Svc: cache filename. See CURLOPT_ALTSVC
Enable and configure Alt-Svc: treatment. See CURLOPT_ALTSVC_CTRL
Set HSTS cache file. See CURLOPT_HSTS
Enable HSTS. See CURLOPT_HSTS_CTRL
Set HSTS read callback. See CURLOPT_HSTSREADFUNCTION
Pass pointer to the HSTS read callback. See CURLOPT_HSTSREADDATA
Set HSTS write callback. See CURLOPT_HSTSWRITEFUNCTION
Pass pointer to the HSTS write callback. See CURLOPT_HSTSWRITEDATA
Do an HTTP GET request. See CURLOPT_HTTPGET
Set the request target. CURLOPT_REQUEST_TARGET
HTTP version to use. CURLOPT_HTTP_VERSION
Allow HTTP/0.9 responses. CURLOPT_HTTP09_ALLOWED
Ignore Content-Length. See CURLOPT_IGNORE_CONTENT_LENGTH
Disable Content decoding. See CURLOPT_HTTP_CONTENT_DECODING
CURLOPT_HTTP_TRANSFER_DECODING
Disable Transfer decoding. See CURLOPT_HTTP_TRANSFER_DECODING
100-continue timeout. See CURLOPT_EXPECT_100_TIMEOUT_MS
Set callback for sending trailing headers. See CURLOPT_TRAILERFUNCTION
Custom pointer passed to the trailing headers callback. See CURLOPT_TRAILERDATA
Wait on connection to pipeline on it. See CURLOPT_PIPEWAIT
This HTTP/2 stream depends on another. See CURLOPT_STREAM_DEPENDS
This HTTP/2 stream depends on another exclusively. See CURLOPT_STREAM_DEPENDS_E
Set this HTTP/2 stream's weight. See CURLOPT_STREAM_WEIGHT
Smtp options
Address of the sender. See CURLOPT_MAIL_FROM
Address of the recipients. See CURLOPT_MAIL_RCPT
Authentication address. See CURLOPT_MAIL_AUTH
Allow RCPT TO command to fail for some recipients. See CURLOPT_MAIL_RCPT_ALLOWFAILS
Tftp options
TFTP block size. See CURLOPT_TFTP_BLKSIZE
Do not send TFTP options requests. See CURLOPT_TFTP_NO_OPTIONS
Ftp options
Use active FTP. See CURLOPT_FTPPORT
Commands to run before transfer. See CURLOPT_QUOTE
Commands to run after transfer. See CURLOPT_POSTQUOTE
Commands to run just before transfer. See CURLOPT_PREQUOTE
Append to remote file. See CURLOPT_APPEND
Use EPRT. See CURLOPT_FTP_USE_EPRT
Use EPSV. See CURLOPT_FTP_USE_EPSV
Use PRET. See CURLOPT_FTP_USE_PRET
CURLOPT_FTP_CREATE_MISSING_DIRS
Create missing directories on the remote server. See CURLOPT_FTP_CREATE_MISSING_DIRS
CURLOPT_SERVER_RESPONSE_TIMEOUT
Timeout for server responses. See CURLOPT_SERVER_RESPONSE_TIMEOUT
CURLOPT_SERVER_RESPONSE_TIMEOUT_MS
Timeout for server responses. See CURLOPT_SERVER_RESPONSE_TIMEOUT_MS
CURLOPT_FTP_ALTERNATIVE_TO_USER
Alternative to USER. See CURLOPT_FTP_ALTERNATIVE_TO_USER
Ignore the IP address in the PASV response. See CURLOPT_FTP_SKIP_PASV_IP
Control how to do TLS. See CURLOPT_FTPSSLAUTH
Back to non-TLS again after authentication. See CURLOPT_FTP_SSL_CCC
Send ACCT command. See CURLOPT_FTP_ACCOUNT
Specify how to reach files. See CURLOPT_FTP_FILEMETHOD
Rtsp options
RTSP request. See CURLOPT_RTSP_REQUEST
RTSP session-id. See CURLOPT_RTSP_SESSION_ID
RTSP stream URI. See CURLOPT_RTSP_STREAM_URI
RTSP Transport: header. See CURLOPT_RTSP_TRANSPORT
Client CSEQ number. See CURLOPT_RTSP_CLIENT_CSEQ
CSEQ number for RTSP Server->Client request. See CURLOPT_RTSP_SERVER_CSEQ
AWS HTTP V4 Signature. See CURLOPT_AWS_SIGV4
Protocol options
Use text transfer. See CURLOPT_TRANSFERTEXT
Add transfer mode to URL over proxy. See CURLOPT_PROXY_TRANSFER_MODE
Convert newlines. See CURLOPT_CRLF
Range requests. See CURLOPT_RANGE
Resume a transfer. See CURLOPT_RESUME_FROM
Resume a transfer. See CURLOPT_RESUME_FROM_LARGE
Set URL to work on with a URL handle. See CURLOPT_CURLU
Custom request/method. See CURLOPT_CUSTOMREQUEST
Request file modification date and time. See CURLOPT_FILETIME
List only. See CURLOPT_DIRLISTONLY
Do not get the body contents. See CURLOPT_NOBODY
Size of file to send. CURLOPT_INFILESIZE
Size of file to send. CURLOPT_INFILESIZE_LARGE
Upload data. See CURLOPT_UPLOAD
Set upload buffer size. See CURLOPT_UPLOAD_BUFFERSIZE
Post/send MIME data. See CURLOPT_MIMEPOST
Set MIME option flags. See CURLOPT_MIME_OPTIONS
Maximum file size to get. See CURLOPT_MAXFILESIZE
Maximum file size to get. See CURLOPT_MAXFILESIZE_LARGE
Make a time conditional request. See CURLOPT_TIMECONDITION
Time value for the time conditional request. See CURLOPT_TIMEVALUE
Time value for the time conditional request. See CURLOPT_TIMEVALUE_LARGE
Connection options
Timeout for the entire request. See CURLOPT_TIMEOUT
Millisecond timeout for the entire request. See CURLOPT_TIMEOUT_MS
Low speed limit to abort transfer. See CURLOPT_LOW_SPEED_LIMIT
Time to be below the speed to trigger low speed abort. See CURLOPT_LOW_SPEED_TIME
Cap the upload speed to this. See CURLOPT_MAX_SEND_SPEED_LARGE
Cap the download speed to this. See CURLOPT_MAX_RECV_SPEED_LARGE
Maximum number of connections in the connection pool. See CURLOPT_MAXCONNECTS
Use a new connection. CURLOPT_FRESH_CONNECT
Prevent subsequent connections from reusing this. See CURLOPT_FORBID_REUSE
Limit the age (idle time) of connections for reuse. See CURLOPT_MAXAGE_CONN
Limit the age (since creation) of connections for reuse. See CURLOPT_MAXLIFETIME_CONN
Timeout for the connection phase. See CURLOPT_CONNECTTIMEOUT
Millisecond timeout for the connection phase. See CURLOPT_CONNECTTIMEOUT_MS
IP version to use. See CURLOPT_IPRESOLVE
Only connect, nothing else. See CURLOPT_CONNECT_ONLY
Use TLS/SSL. See CURLOPT_USE_SSL
Provide fixed/fake name resolves. See CURLOPT_RESOLVE
Bind name resolves to this interface. See CURLOPT_DNS_INTERFACE
Bind name resolves to this IP4 address. See CURLOPT_DNS_LOCAL_IP4
Bind name resolves to this IP6 address. See CURLOPT_DNS_LOCAL_IP6
Preferred DNS servers. See CURLOPT_DNS_SERVERS
Shuffle addresses before use. See CURLOPT_DNS_SHUFFLE_ADDRESSES
Timeout for waiting for the server's connect back to be accepted. See CURLOPT_ACCEPTTIMEOUT_MS
CURLOPT_HAPPY_EYEBALLS_TIMEOUT_MS
Timeout for happy eyeballs. See CURLOPT_HAPPY_EYEBALLS_TIMEOUT_MS
Sets the interval at which connection upkeep are performed. See CURLOPT_UPKEEP_INTERVAL_MS
Ssl and security options
Client cert. See CURLOPT_SSLCERT
Client cert memory buffer. See CURLOPT_SSLCERT_BLOB
Proxy client cert. See CURLOPT_PROXY_SSLCERT
Proxy client cert memory buffer. See CURLOPT_PROXY_SSLCERT_BLOB
Client cert type. See CURLOPT_SSLCERTTYPE
Proxy client cert type. See CURLOPT_PROXY_SSLCERTTYPE
Client key. See CURLOPT_SSLKEY
Client key memory buffer. See CURLOPT_SSLKEY_BLOB
Proxy client key. See CURLOPT_PROXY_SSLKEY
Proxy client key. See CURLOPT_PROXY_SSLKEY_BLOB
Client key type. See CURLOPT_SSLKEYTYPE
Proxy client key type. See CURLOPT_PROXY_SSLKEYTYPE
Client key password. See CURLOPT_KEYPASSWD
Proxy client key password. See CURLOPT_PROXY_KEYPASSWD
Set key exchange curves. See CURLOPT_SSL_EC_CURVES
Enable use of ALPN. See CURLOPT_SSL_ENABLE_ALPN
OBSOLETE Enable use of NPN. See CURLOPT_SSL_ENABLE_NPN
Use identifier with SSL engine. See CURLOPT_SSLENGINE
Default SSL engine. See CURLOPT_SSLENGINE_DEFAULT
Enable TLS False Start. See CURLOPT_SSL_FALSESTART
SSL version to use. See CURLOPT_SSLVERSION
Proxy SSL version to use. See CURLOPT_PROXY_SSLVERSION
Verify the hostname in the SSL certificate. See CURLOPT_SSL_VERIFYHOST
Verify the hostname in the DoH (DNS-over-HTTPS) SSL certificate. See CURLOPT_DOH_SSL_VERIFYHOST
Verify the hostname in the proxy SSL certificate. See CURLOPT_PROXY_SSL_VERIFYHOST
Verify the SSL certificate. See CURLOPT_SSL_VERIFYPEER
Verify the DoH (DNS-over-HTTPS) SSL certificate. See CURLOPT_DOH_SSL_VERIFYPEER
Verify the proxy SSL certificate. See CURLOPT_PROXY_SSL_VERIFYPEER
Verify the SSL certificate's status. See CURLOPT_SSL_VERIFYSTATUS
Verify the DoH (DNS-over-HTTPS) SSL certificate's status. See CURLOPT_DOH_SSL_VERIFYSTATUS
CA cert bundle. See CURLOPT_CAINFO
CA cert bundle memory buffer. See CURLOPT_CAINFO_BLOB
Proxy CA cert bundle. See CURLOPT_PROXY_CAINFO
Proxy CA cert bundle memory buffer. See CURLOPT_PROXY_CAINFO_BLOB
Issuer certificate. See CURLOPT_ISSUERCERT
Issuer certificate memory buffer. See CURLOPT_ISSUERCERT_BLOB
Proxy issuer certificate. See CURLOPT_PROXY_ISSUERCERT
Proxy issuer certificate memory buffer. See CURLOPT_PROXY_ISSUERCERT_BLOB
Path to CA cert bundle. See CURLOPT_CAPATH
Path to proxy CA cert bundle. See CURLOPT_PROXY_CAPATH
Certificate Revocation List. See CURLOPT_CRLFILE
Proxy Certificate Revocation List. See CURLOPT_PROXY_CRLFILE
Timeout for CA cache. See CURLOPT_CA_CACHE_TIMEOUT
Extract certificate info. See CURLOPT_CERTINFO
Set pinned SSL public key . See CURLOPT_PINNEDPUBLICKEY
Set the proxy's pinned SSL public key. See CURLOPT_PROXY_PINNEDPUBLICKEY
OBSOLETE Provide source for entropy random data. See CURLOPT_RANDOM_FILE
OBSOLETE Identify EGD socket for entropy. See CURLOPT_EGDSOCKET
Ciphers to use. See CURLOPT_SSL_CIPHER_LIST
Proxy ciphers to use. See CURLOPT_PROXY_SSL_CIPHER_LIST
TLS 1.3 cipher suites to use. See CURLOPT_TLS13_CIPHERS
Proxy TLS 1.3 cipher suites to use. See CURLOPT_PROXY_TLS13_CIPHERS
Disable SSL session-id cache. See CURLOPT_SSL_SESSIONID_CACHE
Control SSL behavior. See CURLOPT_SSL_OPTIONS
Control proxy SSL behavior. See CURLOPT_PROXY_SSL_OPTIONS
Kerberos security level. See CURLOPT_KRBLEVEL
Disable GSS-API delegation. See CURLOPT_GSSAPI_DELEGATION
Ssh options
SSH authentication types. See CURLOPT_SSH_AUTH_TYPES
Enable SSH compression. See CURLOPT_SSH_COMPRESSION
CURLOPT_SSH_HOST_PUBLIC_KEY_MD5
MD5 of host's public key. See CURLOPT_SSH_HOST_PUBLIC_KEY_MD5
CURLOPT_SSH_HOST_PUBLIC_KEY_SHA256
SHA256 of host's public key. See CURLOPT_SSH_HOST_PUBLIC_KEY_SHA256
Filename of the public key. See CURLOPT_SSH_PUBLIC_KEYFILE
Filename of the private key. See CURLOPT_SSH_PRIVATE_KEYFILE
Filename with known hosts. See CURLOPT_SSH_KNOWNHOSTS
Callback for known hosts handling. See CURLOPT_SSH_KEYFUNCTION
Custom pointer to pass to ssh key callback. See CURLOPT_SSH_KEYDATA
Callback for checking host key handling. See CURLOPT_SSH_HOSTKEYFUNCTION
Custom pointer to pass to ssh host key callback. See CURLOPT_SSH_HOSTKEYDATA
Websocket
Set WebSocket options. See CURLOPT_WS_OPTIONS
Other options
Private pointer to store. See CURLOPT_PRIVATE
Share object to use. See CURLOPT_SHARE
Mode for creating new remote files. See CURLOPT_NEW_FILE_PERMS
Mode for creating new remote directories. See CURLOPT_NEW_DIRECTORY_PERMS
To be set by toplevel tools like "curl" to skip lengthy cleanups when they are about to call exit() anyway. See CURLOPT_QUICK_EXIT
Telnet options
TELNET options. See CURLOPT_TELNETOPTIONS
Example
int main(void) { CURL *curl = curl_easy_init(); if(curl) { CURLcode res; curl_easy_setopt(curl, CURLOPT_URL, "https://example.com"); res = curl_easy_perform(curl); curl_easy_cleanup(curl); } }
Availability
Always
Return value
CURLE_OK (zero) means that the option was set properly, non-zero means an error occurred as <curl/curl.h> defines. See the libcurl-errors man page for the full list with descriptions.
Strings passed on to libcurl must be shorter than 8000000 bytes, otherwise curl_easy_setopt returns CURLE_BAD_FUNCTION_ARGUMENT (added in 7.65.0).
CURLE_BAD_FUNCTION_ARGUMENT is returned when the argument to an option is invalid, like perhaps out of range.
If you try to set an option that libcurl does not know about, perhaps because the library is too old to support it or the option was removed in a recent version, this function returns CURLE_UNKNOWN_OPTION. If support for the option was disabled at compile-time, it returns CURLE_NOT_BUILT_IN.
See also
curl_easy_cleanup(3), curl_easy_getinfo(3), curl_easy_init(3), curl_easy_option_by_id(3), curl_easy_option_by_name(3), curl_easy_option_next(3), curl_easy_reset(3), curl_multi_setopt(3)
This HTML page was made with roffit.