2018-08-05 17:51:07 +08:00
|
|
|
.\" **************************************************************************
|
|
|
|
.\" * _ _ ____ _
|
|
|
|
.\" * Project ___| | | | _ \| |
|
|
|
|
.\" * / __| | | | |_) | |
|
|
|
|
.\" * | (__| |_| | _ <| |___
|
|
|
|
.\" * \___|\___/|_| \_\_____|
|
|
|
|
.\" *
|
2022-01-08 07:28:52 +08:00
|
|
|
.\" * Copyright (C) 1998 - 2022, Daniel Stenberg, <daniel@haxx.se>, et al.
|
2018-08-05 17:51:07 +08:00
|
|
|
.\" *
|
|
|
|
.\" * This software is licensed as described in the file COPYING, which
|
|
|
|
.\" * you should have received as part of this distribution. The terms
|
2020-11-04 21:02:01 +08:00
|
|
|
.\" * are also available at https://curl.se/docs/copyright.html.
|
2018-08-05 17:51:07 +08:00
|
|
|
.\" *
|
|
|
|
.\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
|
|
.\" * copies of the Software, and permit persons to whom the Software is
|
|
|
|
.\" * furnished to do so, under the terms of the COPYING file.
|
|
|
|
.\" *
|
|
|
|
.\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
.\" * KIND, either express or implied.
|
|
|
|
.\" *
|
|
|
|
.\" **************************************************************************
|
|
|
|
.TH curl_url_set 3 "6 Aug 2018" "libcurl" "libcurl Manual"
|
|
|
|
.SH NAME
|
2018-09-09 01:39:57 +08:00
|
|
|
curl_url_set - set a URL part
|
2018-08-05 17:51:07 +08:00
|
|
|
.SH SYNOPSIS
|
2021-11-26 21:20:18 +08:00
|
|
|
.nf
|
|
|
|
#include <curl/curl.h>
|
2018-08-05 17:51:07 +08:00
|
|
|
|
|
|
|
CURLUcode curl_url_set(CURLU *url,
|
|
|
|
CURLUPart part,
|
|
|
|
const char *content,
|
|
|
|
unsigned int flags)
|
|
|
|
.fi
|
|
|
|
.SH DESCRIPTION
|
|
|
|
Given the \fIurl\fP handle of an already parsed URL, this function lets the
|
|
|
|
user set/update individual pieces of it.
|
|
|
|
|
|
|
|
The \fIpart\fP argument should identify the particular URL part (see list
|
2020-06-25 17:38:25 +08:00
|
|
|
below) to set or change, with \fIcontent\fP pointing to a null-terminated
|
2018-08-05 17:51:07 +08:00
|
|
|
string with the new contents for that URL part. The contents should be in the
|
|
|
|
form and encoding they'd use in a URL: URL encoded.
|
|
|
|
|
2021-04-24 23:13:07 +08:00
|
|
|
The application does not have to keep \fIcontent\fP around after a successful
|
|
|
|
call.
|
|
|
|
|
2018-08-05 17:51:07 +08:00
|
|
|
Setting a part to a NULL pointer will effectively remove that part's contents
|
|
|
|
from the CURLU handle.
|
|
|
|
|
|
|
|
The \fIflags\fP argument is a bitmask with independent features.
|
|
|
|
.SH PARTS
|
|
|
|
.IP CURLUPART_URL
|
|
|
|
Allows the full URL of the handle to be replaced. If the handle already is
|
|
|
|
populated with a URL, the new URL can be relative to the previous.
|
|
|
|
|
|
|
|
When successfully setting a new URL, relative or absolute, the handle contents
|
|
|
|
will be replaced with the information of the newly set URL.
|
|
|
|
|
2020-06-25 17:38:25 +08:00
|
|
|
Pass a pointer to a null-terminated string to the \fIurl\fP parameter. The
|
2018-08-05 17:51:07 +08:00
|
|
|
string must point to a correctly formatted "RFC 3986+" URL or be a NULL
|
|
|
|
pointer.
|
|
|
|
.IP CURLUPART_SCHEME
|
2021-11-23 21:16:38 +08:00
|
|
|
Scheme cannot be URL decoded on set. libcurl only accepts setting schemes up
|
|
|
|
to 40 bytes long.
|
2018-08-05 17:51:07 +08:00
|
|
|
.IP CURLUPART_USER
|
|
|
|
.IP CURLUPART_PASSWORD
|
|
|
|
.IP CURLUPART_OPTIONS
|
|
|
|
.IP CURLUPART_HOST
|
2019-09-26 07:12:27 +08:00
|
|
|
The host name. If it is IDNA the string must then be encoded as your locale
|
|
|
|
says or UTF-8 (when WinIDN is used). If it is a bracketed IPv6 numeric address
|
|
|
|
it may contain a zone id (or you can use CURLUPART_ZONEID).
|
2019-05-03 19:18:12 +08:00
|
|
|
.IP CURLUPART_ZONEID
|
|
|
|
If the host name is a numeric IPv6 address, this field can also be set.
|
2018-08-05 17:51:07 +08:00
|
|
|
.IP CURLUPART_PORT
|
2019-04-11 19:20:15 +08:00
|
|
|
Port cannot be URL encoded on set. The given port number is provided as a
|
|
|
|
string and the decimal number must be between 1 and 65535. Anything else will
|
|
|
|
return an error.
|
2018-08-05 17:51:07 +08:00
|
|
|
.IP CURLUPART_PATH
|
|
|
|
If a path is set in the URL without a leading slash, a slash will be inserted
|
|
|
|
automatically when this URL is read from the handle.
|
|
|
|
.IP CURLUPART_QUERY
|
|
|
|
The query part will also get spaces converted to pluses when asked to URL
|
|
|
|
encode on set with the CURLU_URLENCODE bit.
|
|
|
|
|
2018-11-07 06:48:35 +08:00
|
|
|
If used together with the \fICURLU_APPENDQUERY\fP bit, the provided part will
|
2021-10-31 23:34:44 +08:00
|
|
|
be appended on the end of the existing query - and if the previous part did not
|
2018-11-07 06:48:35 +08:00
|
|
|
end with an ampersand (&), an ampersand will be inserted before the new
|
|
|
|
appended part.
|
2018-08-05 17:51:07 +08:00
|
|
|
|
2018-11-07 06:48:35 +08:00
|
|
|
When \fICURLU_APPENDQUERY\fP is used together with \fICURLU_URLENCODE\fP, the
|
|
|
|
first '=' symbol will not be URL encoded.
|
2018-08-05 17:51:07 +08:00
|
|
|
|
|
|
|
The question mark in the URL is not part of the actual query contents.
|
|
|
|
.IP CURLUPART_FRAGMENT
|
|
|
|
The hash sign in the URL is not part of the actual fragment contents.
|
|
|
|
.SH FLAGS
|
|
|
|
The flags argument is zero, one or more bits set in a bitmask.
|
|
|
|
.IP CURLU_NON_SUPPORT_SCHEME
|
|
|
|
If set, allows \fIcurl_url_set(3)\fP to set a non-supported scheme.
|
|
|
|
.IP CURLU_URLENCODE
|
|
|
|
When set, \fIcurl_url_set(3)\fP URL encodes the part on entry, except for
|
|
|
|
scheme, port and URL.
|
|
|
|
|
|
|
|
When setting the path component with URL encoding enabled, the slash character
|
|
|
|
will be skipped.
|
|
|
|
|
|
|
|
The query part gets space-to-plus conversion before the URL conversion.
|
|
|
|
|
|
|
|
This URL encoding is charset unaware and will convert the input on a
|
|
|
|
byte-by-byte manner.
|
2018-09-19 16:17:03 +08:00
|
|
|
.IP CURLU_DEFAULT_SCHEME
|
|
|
|
If set, will make libcurl allow the URL to be set without a scheme and then
|
|
|
|
sets that to the default scheme: HTTPS. Overrides the \fICURLU_GUESS_SCHEME\fP
|
|
|
|
option if both are set.
|
|
|
|
.IP CURLU_GUESS_SCHEME
|
|
|
|
If set, will make libcurl allow the URL to be set without a scheme and it
|
2021-11-26 15:46:59 +08:00
|
|
|
instead "guesses" which scheme that was intended based on the host name. If
|
2018-09-19 16:17:03 +08:00
|
|
|
the outermost sub-domain name matches DICT, FTP, IMAP, LDAP, POP3 or SMTP then
|
|
|
|
that scheme will be used, otherwise it picks HTTP. Conflicts with the
|
2018-10-09 03:37:40 +08:00
|
|
|
\fICURLU_DEFAULT_SCHEME\fP option which takes precedence if both are set.
|
2019-09-19 21:54:53 +08:00
|
|
|
.IP CURLU_NO_AUTHORITY
|
|
|
|
If set, skips authority checks. The RFC allows individual schemes to omit the
|
|
|
|
host part (normally the only mandatory part of the authority), but libcurl
|
|
|
|
cannot know whether this is permitted for custom schemes. Specifying the flag
|
|
|
|
permits empty authority sections, similar to how file scheme is handled.
|
2021-02-21 20:58:47 +08:00
|
|
|
.IP CURLU_PATH_AS_IS
|
|
|
|
When set for \fBCURLUPART_URL\fP, this makes libcurl skip the normalization of
|
2021-10-31 23:34:44 +08:00
|
|
|
the path. That is the procedure where curl otherwise removes sequences of
|
2021-02-21 20:58:47 +08:00
|
|
|
dot-slash and dot-dot etc. The same option used for transfers is called
|
|
|
|
\fICURLOPT_PATH_AS_IS(3)\fP.
|
2021-05-31 14:59:24 +08:00
|
|
|
.IP CURLU_ALLOW_SPACE
|
|
|
|
If set, a the URL parser allows space (ASCII 32) where possible. The URL
|
|
|
|
syntax does normally not allow spaces anywhere, but they should be encoded as
|
|
|
|
%20 or '+'. When spaces are allowed, they are still not allowed in the scheme.
|
|
|
|
When space is used and allowed in a URL, it will be stored as-is unless
|
|
|
|
\fICURLU_URLENCODE\fP is also set, which then makes libcurl URL-encode the
|
|
|
|
space before stored. This affects how the URL will be constructed when
|
|
|
|
\fIcurl_url_get(3)\fP is subsequently used to extract the full URL or
|
2022-01-08 07:28:52 +08:00
|
|
|
individual parts. (Added in 7.78.0)
|
2018-08-05 17:51:07 +08:00
|
|
|
.SH EXAMPLE
|
|
|
|
.nf
|
|
|
|
CURLUcode rc;
|
|
|
|
CURLU *url = curl_url();
|
|
|
|
rc = curl_url_set(url, CURLUPART_URL, "https://example.com", 0);
|
|
|
|
if(!rc) {
|
|
|
|
char *scheme;
|
|
|
|
/* change it to an FTP URL */
|
|
|
|
rc = curl_url_set(url, CURLUPART_SCHEME, "ftp", 0);
|
|
|
|
}
|
|
|
|
curl_url_cleanup(url);
|
|
|
|
.fi
|
|
|
|
.SH AVAILABILITY
|
2021-10-25 17:45:09 +08:00
|
|
|
Added in 7.62.0. CURLUPART_ZONEID was added in 7.65.0.
|
2021-10-25 14:54:08 +08:00
|
|
|
.SH RETURN VALUE
|
|
|
|
Returns a CURLUcode error value, which is CURLUE_OK (0) if everything went
|
2021-11-26 15:46:59 +08:00
|
|
|
fine. See the \fIlibcurl-errors(3)\fP man page for the full list with
|
2021-10-25 14:54:08 +08:00
|
|
|
descriptions.
|
|
|
|
|
|
|
|
A URL string passed on to \fIcurl_url_set(3)\fP for the \fBCURLUPART_URL\fP
|
|
|
|
part, must be shorter than 8000000 bytes otherwise it returns
|
|
|
|
\fBCURLUE_MALFORMED_INPUT\fP (added in 7.65.0).
|
|
|
|
|
|
|
|
If this function returns an error, no URL part is set.
|
2018-08-05 17:51:07 +08:00
|
|
|
.SH "SEE ALSO"
|
|
|
|
.BR curl_url_cleanup "(3), " curl_url "(3), " curl_url_get "(3), "
|
2021-09-27 14:22:54 +08:00
|
|
|
.BR curl_url_dup "(3), " curl_url_strerror "(3), " CURLOPT_CURLU "(3)"
|