curl命令使用记录

author author     2022-08-28     121

关键词:

curl使用记录

curl是一个利用URL规则在命令行下工作的文件传输工具,它支持文件的上传和下载,所以是综合传输工具,习惯称curl为下载工具

curl语法命令:

 

[[email protected] test]# curl -h
Usage: curl [options...] <url>
Options: (H) means HTTP/HTTPS only, (F) means FTP only
    --anyauth       Pick "any" authentication method (H)
 -a/--append        Append to target file when uploading (F/SFTP)
    --basic         Use HTTP Basic Authentication (H)
    --cacert <file> CA certificate to verify peer against (SSL)
    --capath <directory> CA directory to verify peer against (SSL)
 -E/--cert <cert[:passwd]> Client certificate file and password (SSL)
    --cert-type <type> Certificate file type (DER/PEM/ENG) (SSL)
    --ciphers <list> SSL ciphers to use (SSL)
    --compressed    Request compressed response (using deflate or gzip)
 -K/--config <file> Specify which config file to read
    --connect-timeout <seconds> Maximum time allowed for connection
 -C/--continue-at <offset> Resumed transfer offset
    断点续传,第二个 - 表示自动寻找对应的文件,也可以直接指定名称
    curl -C - -O URL
-b/--cookie <name=string/file> Cookie string or file to read cookies from (H) -c/--cookie-jar <file> Write cookies to this file after operation (H) --create-dirs Create necessary local directory hierarchy --crlf Convert LF to CRLF in upload --crlfile <file> Get a CRL list in PEM format from the given file -d/--data <data> HTTP POST data (H) --data-ascii <data> HTTP POST ASCII data (H) --data-binary <data> HTTP POST binary data (H) --data-urlencode <name=data/[email protected]> HTTP POST data url encoded (H) --delegation STRING GSS-API delegation permission --digest Use HTTP Digest Authentication (H) --disable-eprt Inhibit using EPRT or LPRT (F) --disable-epsv Inhibit using EPSV (F) -D/--dump-header <file> Write the headers to this file --egd-file <file> EGD socket path for random data (SSL) --engine <eng> Crypto engine to use (SSL). "--engine list" for list -f/--fail Fail silently (no output at all) on HTTP errors (H) -F/--form <name=content> Specify HTTP multipart POST data (H) --form-string <name=string> Specify HTTP multipart POST data (H) --ftp-account <data> Account data to send when requested by server (F) --ftp-alternative-to-user <cmd> String to replace "USER [name]" (F) --ftp-create-dirs Create the remote dirs if not present (F) --ftp-method [multicwd/nocwd/singlecwd] Control CWD usage (F) --ftp-pasv Use PASV/EPSV instead of PORT (F) -P/--ftp-port <address> Use PORT with address instead of PASV (F) --ftp-skip-pasv-ip Skip the IP address for PASV (F) --ftp-ssl Try SSL/TLS for ftp transfer (F) --ftp-ssl-ccc Send CCC after authenticating (F) --ftp-ssl-ccc-mode [active/passive] Set CCC mode (F) --ftp-ssl-control Require SSL/TLS for ftp login, clear for transfer (F) --ftp-ssl-reqd Require SSL/TLS for ftp transfer (F) -G/--get Send the -d data with a HTTP GET (H) -g/--globoff Disable URL sequences and ranges using {} and [] -H/--header <line> Custom header to pass to server (H) -I/--head Show document info only -h/--help This help text --hostpubmd5 <md5> Hex encoded MD5 string of the host public key. (SSH) -0/--http1.0 Use HTTP 1.0 (H) --ignore-content-length Ignore the HTTP Content-Length header -i/--include Include protocol headers in the output (H/F) -k/--insecure Allow connections to SSL sites without certs (H) --interface <interface> Specify network interface/address to use -4/--ipv4 Resolve name to IPv4 address -6/--ipv6 Resolve name to IPv6 address -j/--junk-session-cookies Ignore session cookies read from file (H) --keepalive-time <seconds> Interval between keepalive probes --key <key> Private key file name (SSL/SSH) --key-type <type> Private key file type (DER/PEM/ENG) (SSL) --krb <level> Enable Kerberos with specified security level (F) --libcurl <file> Dump libcurl equivalent code of this command line --limit-rate <rate> Limit transfer speed to this rate
    限定传输速率,单位字节(B)
-l/--list-only List only names of an FTP directory (F) --local-port <num>[-num] Force use of these local port numbers -L/--location Follow Location: hints (H) --location-trusted Follow Location: and send auth to other hosts (H)
  访问重定向的URL,例如访问 www.google.com 会返回302重定向到 www.google.com.hk
  root #> curl http://www.google.com
-M/--manual Display the full manual --max-filesize <bytes> Maximum file size to download (H/F) --max-redirs <num> Maximum number of redirects allowed (H) -m/--max-time <seconds> Maximum time allowed for the transfer --negotiate Use HTTP Negotiate Authentication (H) -n/--netrc Must read .netrc for user name and password --netrc-optional Use either .netrc or URL; overrides -n -N/--no-buffer Disable buffering of the output stream --no-keepalive Disable keepalive use on the connection --no-sessionid Disable SSL session-ID reusing (SSL) --noproxy Comma-separated list of hosts which do not use proxy --ntlm Use HTTP NTLM authentication (H)
--pass <pass> Pass phrase for the private key (SSL/SSH) --post301 Do not switch to GET after following a 301 redirect (H) --post302 Do not switch to GET after following a 302 redirect (H) -#/--progress-bar Display transfer progress as a progress bar -x/--proxy <host[:port]> Use HTTP proxy on given port --proxy-anyauth Pick "any" proxy authentication method (H) --proxy-basic Use Basic authentication on the proxy (H) --proxy-digest Use Digest authentication on the proxy (H) --proxy-negotiate Use Negotiate authentication on the proxy (H) --proxy-ntlm Use NTLM authentication on the proxy (H) -U/--proxy-user <user[:password]> Set proxy user and password --proxy1.0 <host[:port]> Use HTTP/1.0 proxy on given port -p/--proxytunnel Operate through a HTTP proxy tunnel (using CONNECT) --pubkey <key> Public key file name (SSH) -Q/--quote <cmd> Send command(s) to server before file transfer (F/SFTP) --random-file <file> File for reading random data from (SSL) -r/--range <range> Retrieve only the bytes within a range --raw Pass HTTP "raw", without any transfer decoding (H) -e/--referer Referer URL (H) -O/--remote-name Write output to a file named as the remote file --remote-name-all Use the remote file name for all URLs
     将标准输出导入到文件中,并使用远程文件名作为文件名,可以同时获取多个文件,每个URL都必须添加 -O参数,否则不保存
    同时获取多个URL,将所有的URL的输出保存到和远程文件名相同的本地文件中
    root# > curl -O http://www.cnblogs.com/lvxiaobo616/p/5636006.html -O http://www.cnblogs.com/lvxiaobo616/p/6612900.html
    root# > curl --remote-name-all
http://www.cnblogs.com/lvxiaobo616/p/5636006.html -O http://www.cnblogs.com/lvxiaobo616/p/6612900.html
-R/--remote-time Set the remote files time on the local output
-X/--request <command> Specify request command to use
  --retry <num> Retry request <num> times if transient problems occur
  --retry-delay <seconds> When retrying, wait this many seconds between each
  --retry-max-time <seconds>
Retry only within this period
-S/--show-error Show error. With -s, make curl show errors when they occur
-s/--silent Silent mode. Dont output anything
  --socks4 <host[:port]> SOCKS4 proxy on given host + port
  --socks4a <host[:port]> SOCKS4a proxy on given host + port
  --socks5 <host[:port]> SOCKS5 proxy on given host + port
  --socks5-hostname <host[:port]> SOCKS5 proxy, pass host name to proxy
  --socks5-gssapi-service <name> SOCKS5 proxy service name for gssapi -
  -socks5-gssapi-nec Compatibility with NEC SOCKS5 server
-Y/--speed-limit Stop transfer if below speed-limit for speed-time secs
-y/--speed-time Time needed to trig speed-limit abort. Defaults to 30
-2/--sslv2 Use SSLv2 (SSL)
-3/--sslv3 Use SSLv3 (SSL)
  --stderr <file> Where to redirect stderr. - means stdout
  --tcp-nodelay Use the TCP_NODELAY option
-t/--telnet-option <OPT=val> Set telnet option
-z/--time-cond <time> Transfer based on a time condition
-1/--tlsv1 Use TLSv1 (SSL)
  --trace <file> Write a debug trace to the given file
  --trace-ascii <file> Like --trace but without the hex output
  --trace-time Add time stamps to trace/verbose output
-T/--upload-file <file> Transfer <file> to remote site
  --url <URL> Set URL to work with
-B/--use-ascii Use ASCII/text transfer
-u/--user <user[:password]> Set server user and password
-A/--user-agent <string> User-Agent to send to server (H)
-v/--verbose Make the operation more talkative
-V/--version Show version number and quit
-w/--write-out <format> What to output after completion
-q         If used as the first parameter disables .curlrc

 

 

 

 

crul学习记录

...可以看到网站的响应。1、curl获取web网站返回的网页内容命令:curlhttp://XXXXX 2、curl查看web网站的server信息命令:curl--headhttp://XXXXX如:curl--headhttp://www.baidu.com,输出结果如下图,可看到百度使用的Web服务器是Apachecurl 查看详情

curl常用命令使用(代码片段)

此篇主要是记录日常使用时用到的curl命令的参数和示例。不会像-h一样示例-v输出通信的整个过程-o将服务器的回应保存成文件,可以设置为/dev/null,这样不会缓存到本地curl-o/dev/null"www.baidu.com"-a不知道什么意思,往往和voa... 查看详情

cmd-使用curl命令的注意点(代码片段)

前言最近在cmd中使用curl命令来测试restapi,发现有不少问题,这里记录一下。在cmd中使用curl命令的注意事项json不能由单引号包括起来json数据里的双引号要用反斜杠转义json数据里不能带有空格如果想要在json数据里使用空格则必... 查看详情

报错记录执行curl命令报:没有那个文件或目录(代码片段)

前言执行curl命令的时候报bash:curl******:没有那个文件或目录 命令如下:curl --location --request POST 'http://127.0.0.1:10005/api/test/myTest'我相信你们去执行这个curl命令也会和我一样报错。有人可能会说了,应该是你们服务... 查看详情

es常用curl命令

...到高危需走变更。目前测试版本均为651及以前版本,命令样例基于安全模式,如果是在非安全模式下,将命令中的参数“--tlsv1.2--negotiate-k-u: ” 查看详情

es常用curl命令

...到高危需走变更。目前测试版本均为651及以前版本,命令样例基于安全模式,如果是在非安全模式下,将命令中的参数“--tlsv1.2--negotiate-k-u: ” 查看详情

学习用node.js和elasticsearch构建搜索引擎:实际项目中常用命令使用记录

1、检测集群是否健康。curl-XGET‘localhost:9200/_cat/health?v‘#后面加一个v表示让输出内容表格显示表头绿色表示一切正常,黄色表示所有的数据可用但是部分副本还没有分配,红色表示部分数据因为某些原因不可用。2、查看集群的... 查看详情

windows下使用curl命令&&常用curl命令(代码片段)

阅读目录什么是curl命令?如何在windows下使用curl命令?常用命令如下应用示例什么是curl命令?curl是利用URL语法在命令行方式下工作的开源文件传输工具。它被广泛应用在Unix、多种Linux发行版中,并且有DOS和Win32、... 查看详情

windows下使用curl命令&&常用curl命令(代码片段)

阅读目录什么是curl命令?如何在windows下使用curl命令?常用命令如下应用示例什么是curl命令?curl是利用URL语法在命令行方式下工作的开源文件传输工具。它被广泛应用在Unix、多种Linux发行版中,并且有DOS和Win32、... 查看详情

windows下使用curl命令&&常用curl命令

什么是curl命令?curl是利用URL语法在命令行方式下工作的开源文件传输工具。它被广泛应用在Unix、多种Linux发行版中,并且有DOS和Win32、Win64下的移植版本。 如何在windows下使用curl命令?第一步:进入curl下载官网,下载合适的... 查看详情

windows下使用curl命令&&常用curl命令(代码片段)

什么是curl命令?curl是利用URL语法在命令行方式下工作的开源文件传输工具。它被广泛应用在Unix、多种Linux发行版中,并且有DOS和Win32、Win64下的移植版本。如何在windows下使用curl命令?https://curl.haxx.se/windows/第一步:进入curl下载... 查看详情

基于curl命令行工具进行测试

参考技术AcURL是常用的命令行操作工具,我们会用这个命令必须要进行AccountAPI的调用。cURL只能发起API调用,本身并不具备结果验证能力。比如curl-i-H"Accept:application/json"-XGET"http://127.0.0.1:8080/account/ID"其中命令行参数... 查看详情

curl命令的基本使用

...                       curl命令的基本使用                                        作者:尹正杰版权声明:原创作品,谢绝转载!否则将追究法律... 查看详情

使用 curl 命令发布 git

】使用curl命令发布git【英文标题】:Usingcurlcommandforgitrelease【发布时间】:2018-03-1805:40:32【问题描述】:我不熟悉使用以下命令。我在gitbash中运行了这个命令,但无法创建标签。curl-s-k-XPOST-H"Content-Type:application/json""https://github.co... 查看详情

使用 swift 在 Alamofire 中使用 CURL 命令

】使用swift在Alamofire中使用CURL命令【英文标题】:CURLcommandinAlamofirewithswift【发布时间】:2016-07-2507:58:26【问题描述】:我有以下工作curl命令,我需要使用Alamofire在Swift中运行。curl-k-i-d\'"user":"displayName":"MyTest","email":"test@xxtest.com",... 查看详情

无法在 curl 命令中使用变量 [重复]

】无法在curl命令中使用变量[重复]【英文标题】:Unabletousevariableincurlcommand[duplicate]【发布时间】:2019-08-2703:17:44【问题描述】:我试图在我的ksh程序的curl命令中使用两个变量,但它不起作用。例子:原始网址curl-s--header"Content-Ty... 查看详情

windows下使用curl命令

curl下载地址: https://curl.haxx.se/download.html 选择对应的版本下载后解压使用方式(一):在解压后curl.exe所在目录打开cmd,即可使用 使用方式(二):将curl.exe拷贝到C:WindowsSystem32目录下,这样在任何位置打开cmd即可使用使用方式(三... 查看详情

curl命令使用

curl命令可以用来构造http请求。参数有很多,常用的参数如下:通用语法:curl[option][URL...]在处理URL时其支持类型于SHELL的名称扩展功能,如http://www.jbxue.com/archive[1996-1999]/vol[1-4]/part{a,b,c}.html可以生成多个期望的URLcurl的选项功能:... 查看详情