curl 命令详解

Posted 西北野狼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了curl 命令详解相关的知识,希望对你有一定的参考价值。

 

curl命令是一个利用URL规则在命令行下工作的文件传输工具。它支持文件的上传和下载,所以是综合传输工具,但按传统,习惯称curl为下载工具。
作为一款强力工具,curl支持包括HTTP、HTTPS、ftp等众多协议,还支持POST、cookies、认证、从指定偏移处下载部分文件、用户代理字符串、限速、文件大小、进度条等特征。
做网页处理流程和数据检索自动化,curl可以祝一臂之力。

 

  

-a/--append	上传文件时,附加到目标文件
-A/--user-agent 设置用户代理发送给服务器 
-anyauth	可以使用“任何”身份验证方法
 -b/--cookie cookie字符串或文件读取位置      
--basic	使用HTTP基本验证 
-B/--use-ascii	使用ASCII /文本传输 
-c/--cookie-jar 操作结束后把cookie写入到这个文件中 
-C/--continue-at 断点续转 
-d/--data HTTP POST方式传送数据      
--data-ascii 以ascii的方式post数据      
--data-binary 以二进制的方式post数据      
--negotiate	使用HTTP身份验证      
--digest	使用数字身份验证      
--disable-eprt	禁止使用EPRT或LPRT      
--disable-epsv	禁止使用EPSV -D/
--dump-header 把header信息写入到该文件中      
--egd-file 为随机数据(SSL)设置EGD socket路径      
--tcp-nodelay	使用TCP_NODELAY选项 
-e/--referer	来源网址 -E/
--cert 客户端证书文件和密码 (SSL)      
--cert-type 证书文件类型 (DER/PEM/ENG) (SSL)      
--key 私钥文件名 (SSL)      
--key-type 私钥文件类型 (DER/PEM/ENG) (SSL)      
--pass 私钥密码 (SSL)      
--engine 加密引擎使用 (SSL). "--engine list" for list      --cacert CA证书 (SSL)     
 --capath CA目录 (made using c_rehash) to verify peer against (SSL)      
--ciphers SSL密码      
--compressed	要求返回是压缩的形势 (using deflate or gzip)     
 --connect-timeout 设置最大请求时间      
--create-dirs	建立本地目录的目录层次结构     
 --crlf	上传是把LF转变成CRLF -f/--fail	连接失败时不显示http错误     
 --ftp-create-dirs	如果远程目录不存在,创建远程目录      
--ftp-method [multicwd/nocwd/singlecwd]	控制CWD的使用      
--ftp-pasv	使用 PASV/EPSV 代替端口      
--ftp-skip-pasv-ip	使用PASV的时候,忽略该IP地址      
--ftp-ssl	尝试用 SSL/TLS 来进行ftp数据传输      
--ftp-ssl-reqd	要求用 SSL/TLS 来进行ftp数据传输
 -F/--form 模拟http表单提交数据     
 --form-string 模拟http表单提交数据 
-g/--globoff	禁用网址序列和范围使用{}和[] 
-G/--get	以get的方式来发送数据 
-H/--header 自定义头信息传递给服务器      
--ignore-content-length	忽略的HTTP头信息的长度
 -i/--include	输出时包括protocol头信息
 -I/--head	只显示请求头信息
 -j/--junk-session-cookies	读取文件进忽略session cookie      
--interface 使用指定网络接口/地址      
--krb4 使用指定安全级别的krb4 
-k/--insecure	允许不使用证书到SSL站点 
-K/--config	指定的配置文件读取 
-l/--list-only	列出ftp目录下的文件名称     
 --limit-rate 设置传输速度      
--local-port	强制使用本地端口号
 -m/--max-time 设置最大传输时间     
 --max-redirs 设置最大读取的目录数     
 --max-filesize 设置最大下载的文件总量
 -M/--manual	显示全手动
 -n/--netrc	从netrc文件中读取用户名和密码     
 --netrc-optional	使用 .netrc 或者 URL来覆盖-n      
--ntlm	使用 HTTP NTLM 身份验证 
-N/--no-buffer	禁用缓冲输出 
-o/--output	把输出写到该文件中 
-O/--remote-name	把输出写到该文件中,保留远程文件的文件名 
-p/--proxytunnel	使用HTTP代理     
 --proxy-anyauth	选择任一代理身份验证方法     
 --proxy-basic	在代理上使用基本身份验证     
 --proxy-digest	在代理上使用数字身份验证     
 --proxy-ntlm	在代理上使用ntlm身份验证 
-P/--ftp-port使用端口地址,而不是使用PASV 
-q	作为第一个参数,关闭 .curlrc 
-Q/--quote 文件传输前,发送命令到服务器 
-r/--range 检索来自HTTP/1.1或FTP服务器字节范围 
--range-file	读取(SSL)的随机文件
 -R/--remote-time	在本地生成文件时,保留远程文件时间     
 --retry 传输出现问题时,重试的次数     
 --retry-delay 传输出现问题时,设置重试间隔时间      
--retry-max-time 传输出现问题时,设置最大重试时间
 -s/--silent	静默模式。不输出任何东西 -S/--show-error	显示错误     
 --socks4 用socks4代理给定主机和端口     
 --socks5 用socks5代理给定主机和端口      
--stderr   -t/--telnet-option Telnet选项设置     
 --trace 对指定文件进行debug      
--trace-ascii Like --跟踪但没有hex输出     
 --trace-time	跟踪/详细输出时,添加时间戳 
-T/--upload-file 上传文件     
 --url Spet URL to work with -u/--user 设置服务器的用户和密码
 -U/--proxy-user 设置代理用户名和密码
 -w/--write-out [format]	什么输出完成后
 -x/--proxy 在给定的端口上使用HTTP代理
 -X/--request 指定什么命令 
-y/--speed-time	放弃限速所要的时间,默认为30 
-Y/--speed-limit	停止传输速度的限制,速度时间

利用命令行工具curl 获取公网IP地址:

1. curl  ifconfig.me
2. curl  ipinfo.io
3.查询的时候在ipinfo.io后加上特定ip地址,输出的是这个ip的信息
curl  ipinfo.io/22.138.125.44
4.直接使用:curl ip.cn 显示的内容也比较详细
5.curl http://members.3322.org/dyndns/getip (这个打开显示比较快)

命令说明来源网站:http://man.linuxde.net/curl

以上是关于curl 命令详解的主要内容,如果未能解决你的问题,请参考以下文章

curl 命令详解

postman 自动生成 curl 代码片段

postman 自动生成 curl 代码片段

curl 命令详解

curl命令详解

curl命令详解