Инструменты командной строки для веб-разработчика. Curl поможет управлять данными, размещенными в Web
cURL — инструмент командной строки для получения или отправки данных с использованием синтаксиса URL.
Если вы работаете в службе поддержки, то должны уметь использовать команды cURL для устранения неполадок веб-приложений. cURL
— кроссплатформенная утилита для Windows, MAC и UNIX.
Ниже приведены некоторые часто используемые примеры синтаксиса.
1. Проверка возможности подключения к URL-адресу
Если вы работаете в UNIX-системе и пытаетесь подключиться к внешнему URL-адресу, то сначала проверьте наличие доступа к ресурсу через curl . Для этого используйте следующую команду:
# curl yoururl.com
2. Сохранение вывод URL / URI в файл
# curl yoururl.com > yoururl.html
Например:
# curl 74.125.68.100 >/tmp/google.html
Приведенный выше пример сохранит все содержимое с хоста 74.125.68.100 в файл /tmp/google.html .
3. Показать заголовок запроса и ответа
Если хотите удостовериться, что получаете ожидаемый заголовок запроса и ответа, используйте следующую команду:
# curl -v yoururl.com
например:
# curl -v 74.125.68.100
* About to connect() to 74.125.68.100 port 80 (#0)
* Trying 74.125.68.100...
* Connected to 74.125.68.100 (74.125.68.100) port 80 (#0)
> GET / HTTP/1.1
> User-Agent: curl/7.29.0
>Host: 74.125.68.100
>Accept: */*
>< HTTP/1.1 200 OK
Если нужно узнать, сколько времени требуется для загрузки с определенной скоростью, то используйте следующую команду: # curl –-limit-rate 2000B например: # curl –-limit-rate 2000B 74.125.68.100 Если необходимо проверить, можно ли использовать прокси-сервер, примените следующий синтаксис: # curl --proxyyourproxy:port http://yoururl.com Для устранения конкретной проблемы можно использовать Curl
, чтобы вставить в header
свои данные. Рассмотрим следующий пример запроса с Content-Type: # curl --header "Content-Type: application/json" http://yoururl.com Мы просим curl
передать Content-Type в качестве application / json
в заголовок запроса. Вы можете добавить заголовок к запросу с помощью синтаксиса — header
. # curl –-header “X-CustomHeader: GeekFlare” http://yoururl.com например: # curl -v --header "X-CustomHeader: GeekFlare" 74.125.68
* About to connect() to 74.125.68.100 port 80 (#0)
* Trying 74.125.68.100...
* Connected to 74.125.68.100 (74.125.68.100) port 80 (#0)
> GET / HTTP/1.1
> User-Agent: curl/7.29.0
>Host: 74.125.68.100
>Accept: */*
> X-CustomHeader: GeekFlare
>< HTTP/1.1 200 OK
Если вы хотите быстро проверить заголовок ответа, то для этого можно использовать следующий синтаксис. # curl --head http://yoururl.com # curl -I 74.125.68.100
HTTP/1.1 200 OK
Date: Sun, 18 Jan 2015 08:31:22 GMT
Expires: -1
Cache-Control:
private, max-age=0
Content-Type: text/html; charset=ISO-8859-1
Set-Cookie: NID=67=SpnXKTDUhw7QGakIeLxmDSF;
expires=Mon, 20-Jul-2015 08:31:22 GMT; path=/; domain=.; HttpOnly
P3P: CP="This is not a P3P policy! See http://www.google.com/support/accounts/bin/answer.py?hl=en&answer=151657 for moreinfo."
Server: gws X-XSS-Protection: 1; mode=block
X-Frame-Options: SAMEORIGIN
Alternate-Protocol: 80:quic,p=0.02
Transfer-Encoding: chunked
Accept-Ranges: none
Vary: Accept-Encoding
# Если необходимо получить доступ к https URL-адресу, который выдает ошибку сертификата из-за несоответствия имени хоста, можно использовать следующий синтаксис. curl --insecure https://yoururl.com Чтобы подключиться к URL- адресу только по протоколу SSL V2 / V3
или TLS
,используйте следующий синтаксис. Для подключения с использованием SSLV2: # curl --sslv2 https://yoururl.com Для подключения с использованием SSLV3: # curl --sslv3 https://yoururl.com Для подключения через TLS: # curl --tlsv1 https://yoururl.com С помощью cURL
можно загрузить файл с ftp-сервера
, указав имя пользователя и пароль. # curl -u user:password -O ftp://ftpurl/style.css Всегда можно использовать «-v» с любым синтаксисом для вывода в подробном режиме. Да, это возможно. Вы можете выполнить cURL
удаленно с помощью следующих инструментов. Connect-timeout
--cookie
--data
--header
--head
--location
--max-time
--proxy
--request
--user
--url
--user-agent Пример вывода: cURL
— полезная утилита для устранения проблем с подключением в режиме реального времени. Жизнь веб-разработчика омрачена сложностями. Особенно неприятно, когда источник этих сложностей неизвестен. То ли это проблема с отправкой запроса, то ли с ответом, то ли со сторонней библиотекой, то ли внешний API глючит? Существует куча различных прилад, способных упростить нам жизнь. Вот некоторые инструменты командной строки, которые лично я считаю бесценными. $ curl ifconfig.me
93.96.141.93
$ curl -I сайт
HTTP/1.1 200 OK
Server: nginx
Date: Thu, 18 Aug 2011 14:15:36 GMT
Content-Type: text/html; charset=utf-8
Connection: keep-alive
Keep-alive: timeout=25
Siege
$ siege -g www.google.com
GET / HTTP/1.1
Host: www.google.com
User-Agent: JoeDog/1.00 (X11; I; Siege 2.70)
Connection: close
HTTP/1.1 302 Found
Location: http://www.google.co.uk/
Content-Type: text/html; charset=UTF-8
Server: gws
Content-Length: 221
Connection: close
GET / HTTP/1.1
Host: www.google.co.uk
User-Agent: JoeDog/1.00 (X11; I; Siege 2.70)
Connection: close
HTTP/1.1 200 OK
Content-Type: text/html; charset=ISO-8859-1
X-XSS-Protection: 1; mode=block
Connection: close
$ siege -c20 www.google.co.uk -b -t30s
...
Lifting the server siege... done.
Transactions: 1400 hits
Availability: 100.00 %
Elapsed time: 29.22 secs
Data transferred: 13.32 MB
Response time: 0.41 secs
Transaction rate: 47.91 trans/sec
Throughput: 0.46 MB/sec
Concurrency: 19.53
Successful transactions: 1400
Failed transactions: 0
Longest transaction: 4.08
Shortest transaction: 0.08
$ cut -d " " -f7 /var/log/apache2/access.log > urls.txt
$ siege -c Для веб-трафика вы почти всегда захотите использовать параметр -W
, чтобы сохранить форматирование строк, а также параметр -q
, который скрывает избыточную информацию о неподходящих пакетах. Вот пример команды, которая перехватывает все пакеты с командой GET или POST: Ngrep -q -W byline "^(GET|POST) .*"
Ngrep -q -W byline "search" host www.google.com and port 80 curl offers a busload of useful tricks like proxy support, user
authentication, ftp upload, HTTP post, SSL (https:) connections, cookies, file
transfer resume and more. As you will see below, the amount of features will
make your head spin! curl is powered by libcurl for all transfer-related features. See
(3)
for details.
You can specify multiple URLs or parts of URLs by writing part sets within
braces as in: or you can get sequences of alphanumeric series by using as in: No nesting of the sequences is supported at the moment, but you can use
several ones next to each other: You can specify any amount of URLs on the command line. They will be fetched
in a sequential manner in the specified order. Since curl 7.15.1 you can also specify step counter for the ranges, so that
you can get every Nth number or letter: If you specify URL without protocol:// prefix, curl will attempt to guess what
protocol you might want. It will then default to HTTP but try other protocols
based on often-used host name prefixes. For example, for host names starting
with "ftp." curl will assume you want to speak FTP. However, since curl displays data to the terminal by default, if you invoke
curl to do an operation and it is about to write data to the terminal, it
disables
the progress meter as otherwise it would mess up the output
mixing progress meter and response data. If you want a progress meter for HTTP POST or PUT requests, you need to
redirect the response output to a file, using shell redirect (>), -o or
similar. It is not the same case for FTP upload as that operation is not spitting out
any response data to the terminal. If you prefer a progress "bar" instead of the regular meter, -#
is your
friend.
If this option is used twice, the second one will disable append mode again.
-A/--user-agent If this option is set more than once, the last one will be the one that"s
used.
--anyauth
(HTTP) Tells curl to figure out authentication method by itself, and use the
most secure one the remote site claims it supports. This is done by first
doing a request and checking the response-headers, thus inducing an extra
network round-trip. This is used instead of setting a specific authentication
method, which you can do with --basic
, --digest
, --ntlm
, and
--negotiate
. Note that using --anyauth is not recommended if you do uploads from stdin,
since it may require data to be sent twice and then the client must be able to
rewind. If the need should arise when uploading from stdin, the upload
operation will fail. If this option is used several times, the following occurrences make no
difference.
-b/--cookie If no "=" letter is used in the line, it is treated as a filename to use to
read previously stored cookie lines from, which should be used in this session
if they match. Using this method also activates the "cookie parser" which will
make curl record incoming cookies too, which may be handy if you"re using this
in combination with the -L/--location
option. The file format of the
file to read cookies from should be plain HTTP headers or the Netscape/Mozilla
cookie file format. NOTE
that the file specified with -b/--cookie
is only used as
input. No cookies will be stored in the file. To store cookies, use the
-c/--cookie-jar
option or you could even save the HTTP headers to a file
using -D/--dump-header
! If this option is set more than once, the last one will be the one that"s
used.
-B/--use-ascii
Enable ASCII transfer when using FTP or LDAP. For FTP, this can also be
enforced by using an URL that ends with ";type=A". This option causes data
sent to stdout to be in text mode for win32 systems. If this option is used twice, the second one will disable ASCII usage.
--basic
(HTTP) Tells curl to use HTTP Basic authentication. This is the default and
this option is usually pointless, unless you use it to override a previously
set option that sets a different authentication method (such as --ntlm
,
--digest
and --negotiate
). If this option is used several times, the following occurrences make no
difference.
--ciphers If this option is used several times, the last one will override the others.
--compressed
(HTTP) Request a compressed response using one of the algorithms libcurl
supports, and return the uncompressed document. If this option is used and
the server sends an unsupported encoding, Curl will report an error. If this option is used several times, each occurrence will toggle it on/off.
--connect-timeout If this option is used several times, the last one will be used.
-c/--cookie-jar NOTE
If the cookie jar can"t be created or written to, the whole curl operation
won"t fail or even report an error clearly. Using -v will get a warning
displayed, but that is the only visible feedback you get about this possibly
lethal situation. If this option is used several times, the last specified file name will be
used.
-C/--continue-at Use "-C -" to tell curl to automatically find out where/how to resume the
transfer. It then uses the given output/input files to figure that out. If this option is used several times, the last one will be used.
--create-dirs
When used in conjunction with the -o option, curl will create the necessary
local directory hierarchy as needed. This option creates the dirs mentioned
with the -o option, nothing else. If the -o file name uses no dir or if the
dirs it mentions already exist, no dir will be created. To create remote directories when using FTP, try --ftp-create-dirs
.
--crlf
(FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390). If this option is used several times, the following occurrences make no
difference.
-d/--data
(HTTP) Sends the specified data in a POST request to the HTTP server, in a way
that can emulate as if a user has filled in a HTML form and pressed the submit
button. Note that the data is sent exactly as specified with no extra
processing (with all newlines cut off). The data is expected to be
"url-encoded". This will cause curl to pass the data to the server using the
content-type application/x-www-form-urlencoded. Compare to -F/--form
. If
this option is used more than once on the same command line, the data pieces
specified will be merged together with a separating &-letter. Thus, using "-d
name=daniel -d skill=lousy" would generate a post chunk that looks like
"name=daniel&skill=lousy". If you start the data with the letter @, the rest should be a file name to
read the data from, or - if you want curl to read the data from stdin. The
contents of the file must already be url-encoded. Multiple files can also be
specified. Posting data from a file named "foobar" would thus be done with
--data
@foobar". To post data purely binary, you should instead use the --data-binary
option. -d/--data
is the same as --data-ascii
. If this option is used several times, the ones following the first will
append data.
--data-ascii
(HTTP) This is an alias for the -d/--data
option. If this option is used several times, the ones following the first will
append data.
--data-binary
(HTTP) This posts data in a similar manner as --data-ascii
does,
although when using this option the entire context of the posted data is kept
as-is. If you want to post a binary file without the strip-newlines feature of
the --data-ascii
option, this is for you. If this option is used several times, the ones following the first will
append data.
--digest
(HTTP) Enables HTTP Digest authentication. This is a authentication that
prevents the password from being sent over the wire in clear text. Use this in
combination with the normal -u/--user
option to set user name and
password. See also --ntlm
, --negotiate
and --anyauth
for
related options. If this option is used several times, the following occurrences make no
difference.
--disable-eprt
(FTP) Tell curl to disable the use of the EPRT and LPRT commands when doing
active FTP transfers. Curl will normally always first attempt to use EPRT,
then LPRT before using PORT, but with this option, it will use PORT right
away. EPRT and LPRT are extensions to the original FTP protocol, may not work
on all servers but enable more functionality in a better way than the
traditional PORT command. If this option is used several times, each occurrence will toggle this on/off.
--disable-epsv
(FTP) Tell curl to disable the use of the EPSV command when doing passive FTP
transfers. Curl will normally always first attempt to use EPSV before PASV,
but with this option, it will not try using EPSV. If this option is used several times, each occurrence will toggle this on/off.
-D/--dump-header This option is handy to use when you want to store the headers that a HTTP
site sends to you. Cookies from the headers could then be read in a second
curl invoke by using the -b/--cookie
option! The -c/--cookie-jar
option is however a better way to store cookies. When used on FTP, the ftp server response lines are considered being "headers"
and thus are saved there. If this option is used several times, the last one will be used.
-e/--referer If this option is used several times, the last one will be used.
--engine If this option is used several times, each occurrence will toggle this on/off.
--egd-file If this option is used several times, the last one will be used.
--cert-type If this option is used several times, the last one will be used.
--cacert curl recognizes the environment variable named "CURL_CA_BUNDLE" if that is
set, and uses the given path as a path to a CA cert bundle. This option
overrides that variable. The windows version of curl will automatically look for a CA certs file named
"curl-ca-bundle.crt", either in the same directory as curl.exe, or in the
Current Working Directory, or in any folder along your PATH. If this option is used several times, the last one will be used.
--capath If this option is used several times, the last one will be used.
-f/--fail
(HTTP) Fail silently (no output at all) on server errors. This is mostly done
like this to better enable scripts etc to better deal with failed attempts. In
normal cases when a HTTP server fails to deliver a document, it returns an
HTML document stating so (which often also describes why and more). This flag
will prevent curl from outputting that and return error 22. If this option is used twice, the second will again disable silent failure.
--ftp-account
(FTP) When an FTP server asks for "account data" after user name and password
has been provided, this data is sent off using the ACCT command. (Added in
7.13.0) If this option is used twice, the second will override the previous use.
--ftp-create-dirs
(FTP) When an FTP URL/operation uses a path that doesn"t currently exist on
the server, the standard behavior of curl is to fail. Using this option, curl
will instead attempt to create missing directories. If this option is used twice, the second will again disable directory creation.
--ftp-method
(FTP) Control what method curl should use to reach a file on a FTP(S)
server. The method argument should be one of the following alternatives:
multicwd
curl does a single CWD operation for each path part in the given URL. For deep
hierarchies this means very many commands. This is how RFC1738 says it should
be done. This is the default but the slowest behavior.
nocwd
curl does no CWD at all. curl will do SIZE, RETR, STOR etc and give a full
path to the server for all these commands. This is the fastest behavior.
singlecwd
curl does one CWD with the full target directory and then operates on the file
"normally" (like in the multicwd case). This is somewhat more standards
compliant than "nocwd" but without the full penalty of "multicwd".
--ftp-pasv
(FTP) Use PASV when transferring. PASV is the internal default behavior, but
using this option can be used to override a previous --ftp-port option. (Added
in 7.11.0) If this option is used several times, the following occurrences make no
difference. Ftp-alternative-to-user This option has no effect if PORT, EPRT or EPSV is used instead of PASV. If this option is used twice, the second will again use the server"s suggested
address.
--ftp-ssl
(FTP) Try to use SSL/TLS for the FTP connection.
Reverts to a non-secure connection if the server doesn"t support SSL/TLS.
(Added in 7.11.0) If this option is used twice, the second will again disable this.
--ftp-ssl-reqd
(FTP) Require SSL/TLS for the FTP connection.
Terminates the connection if the server doesn"t support SSL/TLS.
(Added in 7.15.5) If this option is used twice, the second will again disable this.
-F/--form Example, to send your password file to the server, where
"password" is the name of the form-field to which /etc/passwd will be the
input: To read the file"s content from stdin instead of a file, use - where the file
name should"ve been. This goes for both @ and < constructs. You can also tell curl what Content-Type to use by using "type=", in a manner
similar to: curl
-F "[email protected];type=text/html" url.com curl
-F "name=daniel;type=text/foo" url.com You can also explicitly change the name field of an file upload part by
setting filename=, like this: curl
-F "file=@localfile;filename=nameinpost" url.com See further examples and details in the MANUAL. This option can be used multiple times.
--form-string If used in combination with -I, the POST data will instead be appended to the
URL with a HEAD request. If this option is used several times, the following occurrences make no
difference.
-h/--help
Usage help.
-H/--header curl will make sure that each header you add/replace get sent with the proper
end of line marker, you should thus not
add that as a part of the header
content: do not add newlines or carriage returns they will only mess things up
for you. See also the -A/--user-agent
and -e/--referer
options. This option can be used multiple times to add/replace/remove multiple headers.
--ignore-content-length
(HTTP)
Ignore the Content-Length header. This is particularly useful for servers
running Apache 1.x, which will report incorrect Content-Length for files
larger than 2 gigabytes.
-i/--include
(HTTP)
Include the HTTP-header in the output. The HTTP-header includes things
like server-name, date of the document, HTTP-version and more... If this option is used twice, the second will again disable header include.
--interface If this option is used several times, the last one will be used.
-I/--head
(HTTP/FTP/FILE)
Fetch the HTTP-header only! HTTP-servers feature the command HEAD
which this uses to get nothing but the header of a document. When used
on a FTP or FILE file, curl displays the file size and last modification
time only. If this option is used twice, the second will again disable header only.
-j/--junk-session-cookies
(HTTP) When curl is told to read cookies from a given file, this option will
make it discard all "session cookies". This will basically have the same effect
as if a new session is started. Typical browsers always discard session
cookies when they"re closed down. If this option is used several times, each occurrence will toggle this on/off.
-k/--insecure
(SSL) This option explicitly allows curl to perform "insecure" SSL connections
and transfers. All SSL connections are attempted to be made secure by using
the CA certificate bundle installed by default. This makes all connections
considered "insecure" to fail unless -k/--insecure
is used. If this option is used twice, the second time will again disable it.
--key If this option is used several times, the last one will be used.
--key-type If this option is used several times, the last one will be used.
--krb4 This option requires that the library was built with kerberos4 support. This
is not very common. Use -V/--version
to see if your curl supports it. If this option is used several times, the last one will be used.
-K/--config Specify the filename as "-" to make curl read the file from stdin. Note that to be able to specify a URL in the config file, you need to specify
it using the --url
option, and not by simply writing the URL on its own
line. So, it could look similar to this: This option can be used multiple times. When curl is invoked, it always (unless -q
is used) checks for a default
config file and uses it if found. The default config file is checked for in
the following places in this order: 1) curl tries to find the "home dir": It first checks for the CURL_HOME and
then the HOME environment variables. Failing that, it uses getpwuid() on
unix-like systems (which returns the home dir given the current user in your
system). On Windows, it then checks for the APPDATA variable, or as a last
resort the "%USERPROFILE%Application Data". 2) On windows, if there is no _curlrc file in the home dir, it checks for one
in the same dir the executable curl is placed. On unix-like systems, it will
simply try to load .curlrc from the determined home dir.
--limit-rate The given speed is measured in bytes/second, unless a suffix is appended.
Appending "k" or "K" will count the number as kilobytes, "m" or M" makes it
megabytes while "g" or "G" makes it gigabytes. Examples: 200K, 3m and 1G. If you are also using the -Y/--speed-limit
option, that option will take
precedence and might cripple the rate-limiting slightly, to help keeping the
speed-limit logic working. If this option is used several times, the last one will be used.
-l/--list-only
(FTP)
When listing an FTP directory, this switch forces a name-only view.
Especially useful if you want to machine-parse the contents of an FTP
directory since the normal directory view doesn"t use a standard look
or format. This option causes an FTP NLST command to be sent. Some FTP servers
list only files in their response to NLST; they do not include
subdirectories and symbolic links. If this option is used twice, the second will again disable list only.
--local-port If this option is used twice, the second will again disable location following.
--location-trusted
(HTTP/HTTPS) Like -L/--location
, but will allow sending the name +
password to all hosts that the site may redirect to. This may or may not
introduce a security breach if the site redirects you do a site to which
you"ll send your authentication info (which is plaintext in the case of HTTP
Basic authentication). If this option is used twice, the second will again disable location following.
--max-filesize NOTE: The file size is not always known prior to download, and for such files
this option has no effect even if the file transfer ends up being larger than
this given limit. This concerns both FTP and HTTP transfers.
-m/--max-time If this option is used several times, the last one will be used.
-M/--manual
Manual. Display the huge help text.
-n/--netrc
Makes curl scan the .netrc
file in the user"s home directory for login
name and password. This is typically used for ftp on unix. If used with http,
curl will enable user authentication. See
(4)
or
(1)
for details on the file format. Curl will not complain if that file
hasn"t the right permissions (it should not be world nor group
readable). The environment variable "HOME" is used to find the home
directory. A quick and very simple example of how to setup a .netrc
to allow curl
to ftp to the machine host.domain.com with user name "myself" and password
"secret" should look similar to: machine host.domain.com login myself password secret
If this option is used twice, the second will again disable netrc usage.
--netrc-optional
Very similar to --netrc
, but this option makes the .netrc usage
optional
and not mandatory as the --netrc
does.
--negotiate
(HTTP) Enables GSS-Negotiate authentication. The GSS-Negotiate method was
designed by Microsoft and is used in their web applications. It is primarily
meant as a support for Kerberos5 authentication but may be also used along
with another authentication methods. For more information see IETF draft
draft-brezak-spnego-http-04.txt. This option requires that the library was built with GSSAPI support. This is
not very common. Use -V/--version
to see if your version supports
GSS-Negotiate. When using this option, you must also provide a fake -u/--user option to
activate the authentication code properly. Sending a "-u:" is enough as the
user name and password from the -u option aren"t actually used. If this option is used several times, the following occurrences make no
difference.
-N/--no-buffer
Disables the buffering of the output stream. In normal work situations, curl
will use a standard buffered output stream that will have the effect that it
will output the data in chunks, not necessarily exactly when the data arrives.
Using this option will disable that buffering. If this option is used twice, the second will again switch on buffering.
--ntlm
(HTTP) Enables NTLM authentication. The NTLM authentication method was
designed by Microsoft and is used by IIS web servers. It is a proprietary
protocol, reversed engineered by clever people and implemented in curl based
on their efforts. This kind of behavior should not be endorsed, you should
encourage everyone who uses NTLM to switch to a public and documented
authentication method instead. Such as Digest. If you want to enable NTLM for your proxy authentication, then use
--proxy-ntlm
. This option requires that the library was built with SSL support. Use
-V/--version
to see if your curl supports NTLM. If this option is used several times, the following occurrences make no
difference.
-o/--output You may use this option as many times as you have number of URLs. See also the --create-dirs
option to create the local directories
dynamically.
-O/--remote-name
Write output to a local file named like the remote file we get. (Only the file
part of the remote file is used, the path is cut off.) The remote file name to use for saving is extracted from the given URL,
nothing else. You may use this option as many times as you have number of URLs.
--pass If this option is used several times, the last one will be used.
--proxy-anyauth
Tells curl to pick a suitable authentication method when communicating with
the given proxy. This will cause an extra request/response round-trip. (Added
in 7.13.2) If this option is used twice, the second will again disable the proxy use-any
authentication.
--proxy-basic
Tells curl to use HTTP Basic authentication when communicating with the given
proxy. Use --basic
for enabling HTTP Basic with a remote host. Basic is
the default authentication method curl uses with proxies. If this option is used twice, the second will again disable proxy HTTP Basic
authentication.
--proxy-digest
Tells curl to use HTTP Digest authentication when communicating with the given
proxy. Use --digest
for enabling HTTP Digest with a remote host. If this option is used twice, the second will again disable proxy HTTP Digest.
--proxy-ntlm
Tells curl to use HTTP NTLM authentication when communicating with the given
proxy. Use --ntlm
for enabling NTLM with a remote host. If this option is used twice, the second will again disable proxy HTTP NTLM.
-p/--proxytunnel
When an HTTP proxy is used (-x/--proxy
), this option will cause non-HTTP
protocols to attempt to tunnel through the proxy instead of merely using it to
do HTTP-like operations. The tunnel approach is made with the HTTP proxy
CONNECT request and requires that the proxy allows direct connect to the
remote port number curl wants to tunnel through to. If this option is used twice, the second will again disable proxy tunnel.
-P/--ftp-port If this option is used several times, the last one will be used. Disable the
use of PORT with --ftp-pasv
. Disable the attempt to use the EPRT command
instead of PORT by using --disable-eprt
. EPRT is really PORT++.
-q
If used as the first parameter on the command line, the curlrc
config
file will not be read and used. See the -K/--config
for details on the
default config file search path.
-Q/--quote This option can be used multiple times.
--random-file (*) = NOTE that this will cause the server to reply with a multipart
response! You should also be aware that many HTTP/1.1 servers do not have this feature
enabled, so that when you attempt to get a range, you"ll instead get the whole
document. FTP range downloads only support the simple syntax "start-stop" (optionally
with one of the numbers omitted). It depends on the non-RFC command SIZE. If this option is used several times, the last one will be used.
-R/--remote-time
When used, this will make libcurl attempt to figure out the timestamp of the
remote file, and if that is available make the local file get that same
timestamp. If this option is used twice, the second time disables this again.
--retry When curl is about to retry a transfer, it will first wait one second and then
for all forthcoming retries it will double the waiting time until it reaches
10 minutes which then will be the delay between the rest of the retries. By
using --retry-delay
you disable this exponential backoff algorithm. See
also --retry-max-time
to limit the total time allowed for
retries. (Added in 7.12.3) If this option is used multiple times, the last occurrence decide the amount.
--retry-delay If this option is used multiple times, the last occurrence decide the amount.
--retry-max-time If this option is used multiple times, the last occurrence decide the amount.
-s/--silent
Silent mode. Don"t show progress meter or error messages. Makes
Curl mute. If this option is used twice, the second will again disable silent mode.
-S/--show-error
When used with -s it makes curl show error message if it fails. If this option is used twice, the second will again disable show error.
--socks4 -x/--proxy
If this option is used several times, the last one will be used.
--socks5 This option overrides any previous use of -x/--proxy
, as they are
mutually exclusive. If this option is used several times, the last one will be used. (This option
was previously wrongly documented and used as --socks without the number
appended.)
--stderr If this option is used several times, the last one will be used.
--tcp-nodelay
Turn on the TCP_NODELAY option. See the (3)
man page for
details about this option. (Added in 7.11.2) If this option is used several times, each occurrence toggles this on/off.
-t/--telnet-option TTYPE= XDISPLOC= NEW_ENV= Sets an environment variable.
-T/--upload-file Use the file name "-" (a single dash) to use stdin instead of a given file. You can specify one -T for each URL on the command line. Each -T + URL pair
specifies what to upload and to where. curl also supports "globbing" of the -T
argument, meaning that you can upload multiple files to a single URL by using
the same URL globbing style supported in the URL, like this: Нам часто приходится загружать различные файлы из интернета, например, исполняемые файлы программ, файлы скриптов, архивы с исходниками. Но не всегда это нужно делать через браузер. Во многих ситуациях гораздо проще выполнить все действия через терминал. Поскольку таким образом вы можете автоматизировать процесс. С другой стороны, веб-мастерам время от времени приходится тестировать доступность веб-сайтов, проверять отправляемые и получаемые заголовки и многое другое. Для решения таких задач и задач подобного круга можно воспользоваться утилитой curl. Она позволяет решить намного более широкий круг задач, среди которых даже имитация действий пользователя на сайте. В этой статье мы рассмотрим как пользоваться curl, что это такое и зачем нужна эта программа. На самом деле, curl - это больше чем просто утилита командной строки для Linux или Windows. Это набор библиотек, в которых реализуются базовые возможности работы с URL страницами и передачи файлов. Библиотека поддерживает работу с протоколами: FTP, FTPS, HTTP, HTTPS, TFTP, SCP, SFTP, Telnet, DICT, LDAP, а также POP3, IMAP и SMTP. Она отлично подходит для имитации действий пользователя на страницах и других операций с URL адресами. Поддержка библиотеки curl была добавлена в множество различных языков программирования и платформ. Утилита curl - это независимая обвертка для этой библиотеки. Именно на этой утилите мы и остановимся в этой статье. Перед тем как перейти к описанию того как может использоваться команда curl linux, давайте разберем саму утилиту и ее основные опции, которые нам понадобятся. Синтаксис утилиты очень прост: $ curl
опции
ссылка
Теперь рассмотрим основные опции: Это далеко не все параметры curl linux, но здесь перечислено все основное, что вам придется использовать. Мы рассмотрели все, что касается теории работы с утилитой curl, теперь пришло время перейти к практике, и рассмотреть примеры команды curl. Самая частая задача - это . Скачать файл очень просто. Для этого достаточно передать утилите в параметрах имя файла или html страницы: curl https://raw.githubusercontent.com/curl/curl/master/README.md Но тут вас ждет одна неожиданность, все содержимое файла будет отправлено на стандартный вывод. Чтобы записать его в какой-либо файл используйте: curl -o readme.txt https://raw.githubusercontent.com/curl/curl/master/README.md А если вы хотите, чтобы полученный файл назывался так же, как и файл на сервере, используйте опцию -O: curl -O https://raw.githubusercontent.com/curl/curl/master/README.md curl -# -C - -O https://cdn.kernel.org/pub/linux/kernel/v4.x/testing/linux-4.11-rc7.tar.xz Если нужно, одной командой можно скачать несколько файлов: curl -O https://raw.githubusercontent.com/curl/curl/master/README.md -O https://raw.githubusercontent.com/curl/curl/master/README Еще одна вещь, которая может быть полезной администратору - это загрузка файла, только если он был изменен: curl -z 21-Dec-17 https://raw.githubusercontent.com/curl/curl/master/README.md -O https://raw.githubusercontent.com/curl/curl/master/README Вы можете ограничить скорость загрузки до необходимого предела, чтобы не перегружать сеть с помощью опции -Y: curl --limit-rate 50K -O https://cdn.kernel.org/pub/linux/kernel/v4.x/testing/linux-4.11-rc7.tar.xz Здесь нужно указать количество килобайт в секунду, которые можно загружать. Также вы можете разорвать соединение если скорости недостаточно, для этого используйте опцию -Y: curl -Y 100 -O https://raw.githubusercontent.com/curl/curl/master/README.md curl -T login.txt ftp://speedtest.tele2.net/upload/ Или проверим отправку файла по HTTP, для этого существует специальный сервис: curl -T ~/login.txt http://posttestserver.com/post.php В ответе утилита сообщит где вы можете найти загруженный файл. Вы можете отправлять не только файлы, но и любые данные методом POST. Напомню, что этот метод используется для отправки данных различных форм. Для отправки такого запроса используйте опцию -d. Для тестирования будем пользоваться тем же сервисом: curl -d "field1=val&fileld2=val1"http://posttestserver.com/post.php Если вас не устраивает такой вариант отправки, вы можете сделать вид, что отправили форму. Для этого есть опция -F: curl -F "password=@pass;type=text/plain" http://posttestserver.com/post.php Здесь мы передаем формой поле password, с типом обычный текст, точно так же вы можете передать несколько параметров. Куки или Cookie используются сайтами для хранения некой информации на стороне пользователя. Это может быть необходимо, например, для аутентификации. Вы можете принимать и передавать Cookie с помощью curl. Чтобы сохранить полученные Cookie в файл используйте опцию -c: curl -c cookie.txt http://posttestserver.com/post.php Затем можно отправить cookie curl обратно: curl -b cookie.txt http://posttestserver.com/post.php Не всегда нам обязательно нужно содержимое страницы. Иногда могут быть интересны только заголовки. Чтобы вывести только их есть опция -I: curl -I https://сайт А опция -H позволяет или несколько на сервер, например, можно передать заголовок If-Modified-Since чтобы страница возвращалась только если она была изменена: Если на сервере требуется аутентификация одного из распространенных типов, например, HTTP Basic или FTP, то curl очень просто может справиться с такой задачей. Для указания данных аутентификации просто укажите их через двоеточие в опции -u: curl -u ftpuser:ftppass -T - ftp://ftp.testserver.com/myfile_1.txt Точно так же будет выполняться аутентификация на серверах HTTP. Если вам нужно использовать прокси сервер для загрузки файлов, то это тоже очень просто. Достаточно задать адрес прокси сервера в опции -x: curl -x proxysever.test.com:3128 http://google.co.in В этой статье мы рассмотрели как пользоваться curl, зачем нужна эта утилита и основные ее возможности. Несмотря на свою схожесть с , они очень сильно отличаются. Команда curl linux предназначена больше для анализа и имитации различных действий на сервере, тогда как wget больше подходит для загрузки файлов и краулинга сайтов. 16.02.2006
Джеф Феллинг
Curl поможет управлять данными, размещенными в Web
В данной статье рассматривается бесплатный инструмент Curl, с помощью которого можно передавать и принимать Web-страницы из командной строки. Благодаря Curl легко автоматизировать многие В данной статье рассматривается бесплатный инструмент Curl, с помощью которого можно передавать и принимать Web-страницы из командной строки. Благодаря Curl легко автоматизировать многие операции информационной защиты и администрирования, например извлечь Web-страницу для анализа или загрузить исправление для системы безопасности из Web. Curl входит в состав многих дистрибутивов Unix. Имеются двоичные файлы и исходные тексты для большинства других операционных систем. Даже программисты, работающие с открытым PHP, могут использовать Curl для безопасного доступа к Web-контенту непосредственно из PHP-сценариев. Для работы Curl с Web-узлами Secure Sockets Layer (SSL) необходим пакет OpenSSL. Существуют две версии Curl: одна с SSL, другая без SSL. Рекомендую первую, поскольку SSL надежно защищает данные. Прежде чем использовать Curl с функциями SSL, необходимо загрузить из сети и отдельно установить пакет OpenSSL. Двоичные файлы OpenSSL for Windows можно загрузить с сайта проекта GnuWin32 SourceForge по адресу . На этом сайте имеется и много других полезных инструментов, портированных в Windows. Следует загрузить и установить пакет OpenSSL, затем скопировать два DLL-файла в каталог system32: Copy "C:Program
FilesGnuWin32
binlibeay32.dll"
%windir%system32
copy "C:Program
FilesGnuWin32
binlibssl32.dll"
%windir%system32
После этого можно установить Curl. SSL-совместимые двоичные файлы Curl для Windows можно найти по адресу http://curl.haxx.se/latest.cgi?curl=win32-ssl-sspi
. Новейшая версия, curl 7.15.0, находится в win32-ssl-sspi.zip, который содержит файл curl.exe и документацию. После установки Curl следует убедиться в его работоспособности, введя команду Curl http://isc.sans.org/
infocon.txt
Если на экране появится слово, обозначающее цвет (например, green), значит, Curl работает. В этом простом примере Curl извлекает содержание Infocon из Web-узла Internet Storm Center института SANS. Green означает, что Internet функционирует нормально и серьезных угроз не обнаружено. Если же вместо green на экране появляются слова yellow, orange или red, то отложите эту статью и посетите сайт http://isc.sans.org
, чтобы узнать о состояниях повышенной опасности в Internet. В случае ошибки необходимо проверить правильность установки Curl. В сущности, Curl извлекает Web-страницу, а затем выдает исходный текст HTML страницы на консоль. Однако возможности утилиты шире. Curl располагает встроенной функцией проверки ошибок. Например, команда Curl http://noserverhere
выдает ошибку Curl: (6) Could not resolve host: noserverhere; Host not found. Коды ошибок можно использовать в сценариях, чтобы проверить доступность Web-страницы или реакцию Web-сервера. Например, если использовать Curl для ежедневного извлечения Web-страницы, в частности суточной статистики Web-узла, можно дополнить сценарий исходным текстом, отыскивающим коды ошибок. Если Curl выдает код ошибки Curl: (7) couldn?t connect to host, то можно немедленно передать предупреждение или отправить сообщение по электронной почте. Одно из важнейших достоинств Curl - совместимость с SSL. Запрошенные страницы HTTPS передаются через сеть в зашифрованном виде, а затем Curl выводит на экран восстановленный текст. Кроме того, Curl проверяет сертификаты - дату завершения действия сертификата, соответствие имени хост-компьютера хост-имени в сертификате и уровень доверия к корневому сертификату - и предупреждает, если сертификат некорректен. Параметр -cacert позволяет указать определенный файл сертификата. Проверка сертификатов отменяется с помощью параметра -k. Альтернативный подход - использовать параметр -insecure. Возможности Curl шире простой пересылки файлов через Internet. С помощью Curl можно быстро получить список каталогов FTP-сайта: Curl ftp://myftpsite
Чтобы увидеть подкаталоги сайта, следует ввести команду Curl ftp://myftpsite/subdir/
Для загрузки файла из сети достаточно указать в URL имя файла. В следующем примере файл с именем readme.txt загружается прямо из командной строки и отображается на экране: Curl ftp://ftp.microsoft.com/
deskapps/games/readme.txt
Нередко проще подготовить сценарий с Curl для ввода FTP-файлов, чем использовать команду FTP интерактивно. По умолчанию данные выводятся непосредственно на консоль, но их можно перенаправить в файл с помощью параметров -o и -O. Чтобы получить страницу и сохранить ее на диске, следует указать параметр -o. Параметр -O сохраняет полученную страницу в локальном файле, и Curl извлекает имя удаленного документа. Если в URL имя файла не указано, то эта операция закончится неудачей. Если использовать Curl для передачи на Web-узел запроса без имени файла, но нужно сохранить результат в файле, можно указать имя файла в командной строке, например: Curl обеспечивает методы аутентификации Basic, Digest и интегрированный. На большинстве сайтов доступ к страницам с аутентификацией на базе форм можно получить с использованием функций отправки Curl, что будет продемонстрировано чуть ниже. Это значит, что можно передать данные формы, в частности имя пользователя и пароль, на удаленный Web-узел, на Web-странице которого выводится запрос на ввод информации. Для пересылки учетных данных можно использовать параметр -u или вставить их в URL, что традиционно делается в FTP, например: Curl ftp://username:
password@myhtmlsite
С помощью Curl приемы, заимствованные из FTP, можно перенести в HTTP, как в следующем примере: Curl http://username:password
@myhtmlsite/default.htm
Curl также обеспечивает доступ к Web-страницам через proxy-сервер. Поэтому Curl можно настроить на использование proxy-сервера для аутентификации в режимах Basic, Digest и NTLM. В одной статье трудно охватить все многочисленные функции Curl, среди которых и загрузка файлов на сервер (-T), и просмотр только информации в заголовке HTTP (-I), и просмотр всех данных в детальном режиме (-V), и скрытый вывод (-s). Я рекомендую более подробно ознакомиться с функциями Curl в руководстве, опубликованном по адресу http://curl.haxx.se/docs
. Ознакомившись с основами Curl, рассмотрим простой пример извлечения данных из Web-узла при заданных входных данных. Построим простой инструмент Whois, который демонстрирует простоту и удобство применения Curl и процедуру отправки данных на Web-узел с использованием параметра -d. В данном примере Curl посылает IP-адрес на Web-узел Arin Whois, а затем извлекает результаты из этого сайта. Whois отыскивает информацию о владельце IP-адреса. Перед началом работы важно исследовать Web-узел, так как в исходном тексте каждого сайта есть свои особенности, и Curl не всегда одинаково работает с любыми сайтами. Предварительное посещение сайта позволяет собрать необходимую информацию для работы Curl. В данном примере я воспользовался браузером, чтобы посетить Web-узел http://www.arin.net/whois/
, и обратил внимание, что на сайте имеется единственное поле ввода данных, в котором посетители указывают интересующий их IP-адрес. Необходимо получить детали этого поля, которое представляет собой часть Web-формы. В данном примере используется Perl-сценарий formfind.pl (http://cool.haxx.se/cvs.cgi/curl/perl/contrib/ formfind?rev=HEAD&content-type=text/vnd.viewcvs-markup
). Сценарий Formfind.pl преобразует данные формы в удобные выходные результаты и упрощает ручной поиск данных в HTML. Конечно, для запуска Formfind на компьютере должен быть развернут Perl. Хороший пакет Win32 Perl можно заказать на сайте ActiveState ActivePerl по адресу http://www.activestate.com
. Рассмотрим пример более подробно. Во-первых, обратимся к Web-узлу, содержащему форму, которая запрашивает информацию: Curl -o whoisOutputFile
http://www.arin.net/whois/
Эта команда извлекает страницу Whois из http://www.arin.net и сохраняет ее в текстовом файле whoisOutputFile, который содержит исходный текст HTML, воспроизводимый браузером при посещении сайта. Затем необходимо найти и выделить данные формы: ./formfind.pl Formfind выдает переменные формы и их возможные величины. В данном примере выходные результаты имеют довольно простой вид (см. экран 1
). Следует обратить внимание на данные формы Input с именем queryinput. Это текстовое поле, в которое Curl должен послать искомый IP-адрес. Конкретный IP-адрес не имеет значения - в данном примере использовался адрес Microsoft. С помощью параметра -d искомый IP-адрес пересылается в поле queryinput: Curl -d "queryinput=
207.46.133.140"
http://ws.arin.net/cgibin/
whois.pl
Команда Curl с параметром -d отыскивает данные в форме, в данном случае queryinput, которые представляют собой искомый IP-адрес. При этом меняется целевой адрес; форма должна передавать данные на новый URL, который представляет сценарий whois.pl. Новый целевой адрес можно увидеть на выходе formfind на экране 1. В данном примере также получен исходный текст HTML ответа Whois, но он скрыт группой тэгов HTML. По умолчанию сообщение о статусе Curl показывает размер документа, процент выполнения и скорость пересылки. Выходные данные можно немного расчистить и отфильтровать имя организации, которой принадлежит IP-адрес. Статус Curl можно блокировать с помощью параметра -s. Команду следует выполнять через grep, чтобы получить только OrgName: Curl -s -d "queryinput=
207.46.133.140"
http://ws.arin.net/cgibin/
whois.pl
| grep OrgName
В данном примере выходные результаты показывают, что OrgName - Microsoft Corp. @echo off
curl -k -s -d "queryinput=
%1" http://ws.arin.net/cgibin/
whois.pl | grep OrgName
4. Загрузить с предельной скоростью
5. Использование прокси для подключения
6. Проверка URL-адресас введением заголовка
7. Добавить дополнительный заголовок
8. Открыть только заголовок ответа
9. Подключить HTTPS / SSLURL-адрес и игнорировать любые ошибки SSL -сертификата
10. Подключиться с использованием определенного протокола (SSL / TLS)
11. Загрузить файл с FTP-сервера
Использования cURL онлайн
Online CURL
— компактный инструмент для извлечения URL-адреса онлайн и добавления следующих параметров.
cURL command line builder
–позволяет создать команду cURL, с помощью которой можно ввести информацию в пользовательский интерфейс.
cURL
cURL - программа для передачи данных по различным протоколам, похожая на wget. Основное отличие в том, что по умолчанию wget сохраняет в файл, а cURL выводит в командную строку. Так можно очень просто посмотреть контент веб-сайта. Например, вот как быстро получить свой текущий внешний IP:
Параметры -i
(показывать заголовки) и -I
(показывать только заголовки) делают cURL отличным инструментом для дебаггинга HTTP-ответов и анализа того, что конкретно сервер вам отправляет:
Параметр -L
тоже полезный, он заставляет cURL автоматически следовать по редиректам. cURL поддерживает HTTP-аутентификацию, cookies, туннелирование через HTTP-прокси, ручные настройки в заголовках и многое, многое другое.
- инструмент для нагрузочного тестирования. Плюс, у него есть удобная опция -g
, которая очень похожа на curl –iL
, но вдобавок показывает вам ещё и заголовки http-запроса. Вот пример с google.com (некоторые заголовки удалены для краткости):
Но для чего Siege действительно великолепно подходит, так это для нагрузочного тестирования. Как и апачевский бенчмарк ab
, он может отправить множество параллельных запросов к сайту и посмотреть, как он справляется с трафиком. В следующем примере показано, как мы тестируем Google с помощью 20 запросов в течение 30 секунд, после чего выводится результат:
Одна из самых полезных функций Siege - то, что он может работать не только с одним адресом, но и со списком URL’ов из файла. Это отлично подходит для нагрузочного тестирования, потому что можно моделировать реальный трафик на сайте, а не просто жать один и тот же URL снова и снова. Например, вот как использовать Siege, чтобы нагрузить сервер, используя адреса из вашего лога Apache:
Ngrep
Для серьёзного анализа трафика существует Wireshark с тысячами настроек, фильтров и конфигураций. Есть также версия для командной строки tshark
. Но для простых задач функционал Wireshark я считаю избыточным. Так что до тех пор, пока мне не нужно мощное оружие, я использую . Он позволяет делать с сетевыми пакетами то же самое, что grep
делает с файлами.
Вы можете добавить дополнительный фильтр для пакетов, например, по заданному хосту, IP-адресу или порту. Вот фильтр для всего входящего и исходящего трафика на google.com, порт 80, который содержит слово “search”.NAME
curl - transfer a URL
SYNOPSIS
curl
DESCRIPTION
curl
is a tool to transfer data from or to a server, using one of the supported
protocols (HTTP, HTTPS, FTP, FTPS, TFTP, DICT, TELNET, LDAP or FILE).
The command is designed to work without user interaction.
URL
The URL syntax is protocol dependent. You"ll find a detailed description in
RFC 3986.
PROGRESS METER
curl normally displays a progress meter during operations, indicating amount
of transfered data, transfer speeds and estimated time left etc.
OPTIONS
-a/--append
(FTP) When used in an FTP upload, this will tell curl to append to the target
file instead of overwriting it. If the file doesn"t exist, it will be created.
(SSL) Specifies which ciphers to use in the connection. The list of ciphers
must be using valid ciphers. Read up on SSL cipher list details on this URL:
http://www.openssl.org/docs/apps/ciphers.html
FILES
~/.curlrc
Default config file, see -K/--config
for details.
ENVIRONMENT
http_proxy EXIT CODES
There exists a bunch of different error codes and their corresponding error
messages that may appear during bad conditions. At the time of this writing,
the exit codes are:
1
Unsupported protocol. This build of curl has no support for this protocol.
2
Failed to initialize.
3
URL malformat. The syntax was not correct.
4
URL user malformatted. The user-part of the URL syntax was not correct.
5
Couldn"t resolve proxy. The given proxy host could not be resolved.
6
Couldn"t resolve host. The given remote host was not resolved.
7
Failed to connect to host.
8
FTP weird server reply. The server sent data curl couldn"t parse.
9
FTP access denied. The server denied login or denied access to the particular
resource or directory you wanted to reach. Most often you tried to change to a
directory that doesn"t exist on the server.
10
FTP user/password incorrect. Either one or both were not accepted by the
server.
11
FTP weird PASS reply. Curl couldn"t parse the reply sent to the PASS request.
12
FTP weird USER reply. Curl couldn"t parse the reply sent to the USER request.
13
FTP weird PASV reply, Curl couldn"t parse the reply sent to the PASV request.
14
FTP weird 227 format. Curl couldn"t parse the 227-line the server sent.
15
FTP can"t get host. Couldn"t resolve the host IP we got in the 227-line.
16
FTP can"t reconnect. Couldn"t connect to the host we got in the 227-line.
17
FTP couldn"t set binary. Couldn"t change transfer method to binary.
18
Partial file. Only a part of the file was transferred.
19
FTP couldn"t download/access the given file, the RETR (or similar) command
failed.
20
FTP write error. The transfer was reported bad by the server.
21
FTP quote error. A quote command returned error from the server.
22
HTTP page not retrieved. The requested url was not found or returned another
error with the HTTP error code being 400 or above. This return code only
appears if -f/--fail
is used.
23
Write error. Curl couldn"t write data to a local filesystem or similar.
24
Malformed user. User name badly specified.
25
FTP couldn"t STOR file. The server denied the STOR operation, used for FTP
uploading.
26
Read error. Various reading problems.
27
Out of memory. A memory allocation request failed.
28
Operation timeout. The specified time-out period was reached according to the
conditions.
29
FTP couldn"t set ASCII. The server returned an unknown reply.
30
FTP PORT failed. The PORT command failed. Not all FTP servers support the PORT
command, try doing a transfer using PASV instead!
31
FTP couldn"t use REST. The REST command failed. This command is used for
resumed FTP transfers.
32
FTP couldn"t use SIZE. The SIZE command failed. The command is an extension
to the original FTP spec RFC 959.
33
HTTP range error. The range "command" didn"t work.
34
HTTP post error. Internal post-request generation error.
35
SSL connect error. The SSL handshaking failed.
36
FTP bad download resume. Couldn"t continue an earlier aborted download.
37
FILE couldn"t read file. Failed to open the file. Permissions?
38
LDAP cannot bind. LDAP bind operation failed.
39
LDAP search failed.
40
Library not found. The LDAP library was not found.
41
Function not found. A required LDAP function was not found.
42
Aborted by callback. An application told curl to abort the operation.
43
Internal error. A function was called with a bad parameter.
44
Internal error. A function was called in a bad order.
45
Interface error. A specified outgoing interface could not be used.
46
Bad password entered. An error was signaled when the password was entered.
47
Too many redirects. When following redirects, curl hit the maximum amount.
48
Unknown TELNET option specified.
49
Malformed telnet option.
51
The remote peer"s SSL certificate wasn"t ok
52
The server didn"t reply anything, which here is considered an error.
53
SSL crypto engine not found
54
Cannot set SSL crypto engine as default
55
Failed sending network data
56
Failure in receiving network data
57
Share is in use (internal error)
58
Problem with the local certificate
59
Couldn"t use specified SSL cipher
60
Problem with the CA cert (path? permission?)
61
Unrecognized transfer encoding
62
Invalid LDAP URL
63
Maximum file size exceeded
64
Requested FTP SSL level failed
65
Sending the data requires a rewind that failed
66
Failed to initialise SSL Engine
67
User, password or similar was not accepted and curl failed to login
68
File not found on TFTP server
69
Permission problem on TFTP server
70
Out of disk space on TFTP server
71
Illegal TFTP operation
72
Unknown TFTP transfer ID
73
File already exists (TFTP)
74
No such user (TFTP)
75
Character conversion failed
76
Character conversion functions required
XX
There will appear more error codes here in future releases. The existing ones
are meant to never change.
Команда curl
Как пользоваться curl?
Ограничение скорости
Передача файлов
Отправка данных POST
Передача и прием куки
Передача и анализ заголовков
Аутентификация curl
Использование прокси
Выводы
Curl поможет управлять данными, размещенными в Web
Установка Curl
Извлечение шифрованных данных
Не только для WWW
Аутентификация
Читайте документацию
Пример использования Curl