Welcome everyone

what is curl ?

linux 汪明鑫 733浏览 1评论

应用上预生产环境了,由于某些限制没法像在测试环境那样使用postman直接请求接口

下游让我造些数据,没入口,也不能直接操作线上数据库写数据,沃日

可以登陆机器,在机器中使用 linux的 curl 命令调Java接口

那么curl是不是就只是用来调服务器上接口?

curl还有很多用处,更多简单介绍见下文

what is curl?

 

 

curl 是一种命令行工具,作用是发出网络请求,然后获取数据,还支持文件的上传和下载

curl可以模拟各种请求协议向服务端发送请求,是一个很好用的接口测试命令行工具。

curl支持包括HTTP、HTTPS、ftp等众多协议,还支持POST、cookies、认证、从指定偏移处下载部分文件、用户代理字符串、限速、文件大小、进度条等特征。

 

curl is a tool to transfer data from or to a server, using one of the supported protocols (DICT, FILE, FTP, FTPS, GOPHER, HTTP, HTTPS, IMAP, IMAPS, LDAP, LDAPS, POP3, POP3S, RTMP, RTSP, SCP, SFTP, SMB, SMBS, SMTP, SMTPS, TELNET and TFTP). The command is designed to work without user interaction.

curl offers a busload of useful tricks like proxy support, user authentication, FTP upload, HTTP post, SSL connections, cookies, file transfer resume, Metalink, and more.

 

总之,curl是一个强力神器

 

关键参数如下:

-X/–request :指定请求的方法,如  [GET|POST|PUT|DELETE|…]
-H/–header :设置请求头 ,如 “Content-Type:application/json”,可以使用多个 -H
-i/–include :显示响应头
-d/–data:设置请求参数 ,如 “name=xiaoming”
-u/–user:登录之后才能调用的请求需要使用,如  “name:pwd”
-b/–cookie:使用cookie,指定cookie文件路径

 

来几个实例感受一下:

[root@xinyeshuaiqi ~]# curl www.baidu.com

把百度的源码拉下来了。。。

 

[root@xinyeshuaiqi ~]# curl -o /lol  https://lol.qq.com/
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100  3307    0  3307    0     0  17753      0 --:--:-- --:--:-- --:--:-- 17779

-o 把英雄联盟官网的源码拉下来保存到指定文件

 

[root@xinyeshuaiqi ~]# curl -i  https://lol.qq.com/

-i 显示http response 的头信息

-I 只显示http response 的头信息

 

 

显示一个完整的通信过程:

[root@xinyeshuaiqi ~]# curl -v  https://lol.qq.com/ 
* About to connect() to lol.qq.com port 443 (#0)
*   Trying 123.125.9.91...
* Connected to lol.qq.com (123.125.9.91) port 443 (#0)
* Initializing NSS with certpath: sql:/etc/pki/nssdb
*   CAfile: /etc/pki/tls/certs/ca-bundle.crt
  CApath: none
* SSL connection using TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256
* Server certificate:
*       subject: CN=game.qq.com,OU=R&D,O=Shenzhen Tencent Computer Systems Company Limited,L=Shenzhen,ST=Guangdong,C=CN
*       start date: Oct 29 00:00:00 2019 GMT
*       expire date: Nov 02 12:00:00 2020 GMT
*       common name: game.qq.com
*       issuer: CN=Secure Site CA G2,OU=www.digicert.com,O=DigiCert Inc,C=US
> GET / HTTP/1.1
> User-Agent: curl/7.29.0
> Host: lol.qq.com
> Accept: */*
> 
< HTTP/1.1 200 OK
< Server: NWSs
< Date: Thu, 19 Dec 2019 08:37:07 GMT
< Content-Type: text/html
< Transfer-Encoding: chunked
< Connection: keep-alive
< Cache-Control: max-age=60
< Expires: Thu, 19 Dec 2019 08:38:06 GMT
< Last-Modified: Thu, 19 Dec 2019 08:30:00 GMT
< X-NWS-LOG-UUID: 802e0870-93c8-4768-9c41-51f89bad43e5
< X-Cache-Lookup: Hit From Upstream

 

get请求:

curl -X GET  'http://127.0.0.1:8080/getInfo'  --header 'sessionid:123456789'     //设置请求头带 sessionid

 

post请求:

curl -X POST "http://127.0.0.1:8080/getInfo" -H "Content-Type:application/json"  -d ""dataparams":{ "name":"xiaoming","type":"A"}"

 

 

附curl参数大全

-a/–append 上传文件时,附加到目标文件
-A/–user-agent 设置用户代理发送给服务器
-anyauth 可以使用“任何”身份验证方法
-b/–cookie<name=string file=””> 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<cert:[passwd]> 客户端证书文件和密码 (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<name=content> 模拟http表单提交数据
–form-string<name=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<host[:port]> 用socks4代理给定主机和端口
–socks5<host[:port]> 用socks5代理给定主机和端口
–stderr
-t/–telnet-option<opt=val> Telnet选项设置
–trace 对指定文件进行debug
–trace-ascii Like –跟踪但没有hex输出
–trace-time 跟踪/详细输出时,添加时间戳
-T/–upload-file 上传文件
–url Spet URL to work with
-u/–user<user[:password]> 设置服务器的用户和密码
-U/–proxy-user<user[:password]> 设置代理用户名和密码
-w/–write-out [format] 什么输出完成后
-x/–proxy<host[:port]> 在给定的端口上使用HTTP代理
-X/–request 指定什么命令
-y/–speed-time 放弃限速所要的时间,默认为30
-Y/–speed-limit 停止传输速度的限制,速度时间

 

 

 

 

转载请注明:汪明鑫的个人博客 » what is curl ?

喜欢 (1)

说点什么

1 评论 在 "what is curl ?"

提醒
avatar
排序:   最新 | 最旧 | 得票最多
dscsd
游客

dfv

wpDiscuz