curl
是一个极其强大的命令行传输数据的工具和库,其作用远超过常用的文件加载功能,可以用于各种网络应用协议交互核测试。
如果要通过curl将文本文件内容发送给网站( post
),使用@
符号:
-d
表示数据,也可以是--data
。注意,文件名前面一定要加上@
符号。
curl -k https://<SERVER_IP>/API/xyz -H 'Content-Type: application/json' -d @/var/log/example.log
-k
表示--insecure
,不校验服务器SSL安全性 ,请参考 How to ignore invalid and self signed ssl connection errors with curl 。特别适合很多内网部署服务,自己签发的非正式证书。
如果是使用curl上传文件,则使用:
curl --from "[email protected]" http://hostname/resource
- 使用RESTful HTTP post:
curl -X POST -d @filename http://hostname/resource
- 提交json数据案例:
curl -XPOST --data '{"data": 123}' api.example.com/data
curl -XPOST --data @data.json api.example.com/data
- 登录网站(auth):将登录信息记录到headers,后续curl都使用headers
curl -d "username=admin&password=admin&submit=Login" --dump-header headers http://localhost/Login
curl -L -b headers http://localhost/
curl -v https://www.baidu.com
如果服务器是自签名证书,则加上 -k
参数。如果想要禁止证书警告,例如你的自签名证书服务器,你需要下载文件,忽略证书告警,在使用参数 -I
:
curl -k -O https://202.54.1.2/file.tar.gz
另外,如果你仅仅想截取证书信息,则参考
提交json数据,字段也可以是null
(例如暂时不知道的字段):
curl -k -u user_name:user_password -H "Accept: version=2,application/json" -H "Content-Type: application/json" -X POST -d '{"name": "tom", "phone": null, "address": "x road, y room", "crash_time": "2018-07-26 06:48:02"}' http://myapp.com/api/contact/
可以指定自签名证书
curl --cacert /pth/to/my/ca.pem https://url
curl --header 'Host: www.cyberciti.biz' --cacert /pth/to/my/ca.pem https://207.5.1.10/nixcraft.tar.gz
参考 how to use curl to verify if a site's certificate has been revoked?
使用以下命令获取服务器证书信息(例如检查服务器证书到期时间):
curl --insecure -v https://www.baidu.com 2>&1 | awk 'BEGIN { cert=0 } /^\* Server certificate:/ { cert=1 } /^\*/ { if (cert) print }'
输出可以看到:
* Server certificate:
* subject: C=CN; ST=beijing; L=beijing; OU=service operation department; O=Beijing Baidu Netcom Science Technology Co., Ltd; CN=baidu.com
* start date: May 9 01:22:02 2019 GMT
* expire date: Jun 25 05:31:02 2020 GMT
* issuer: C=BE; O=GlobalSign nv-sa; CN=GlobalSign Organization Validation CA - SHA256 - G2
* SSL certificate verify ok.
* Connection #0 to host www.baidu.com left intact
* Closing connection 0
在内网或者生产环境,往往会使用代理服务器来实现集中的internet访问以及缓存加速。curl命令也支持代理功能,只需要设置shell环境变量就可以:
export http_proxy=http://your.proxy.server:port/
export https_proxy=https://your.proxy.server:port/