应用上预生产环境了,由于某些限制没法像在测试环境那样使用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 评论 在 "what is curl ?"
dfv