ubuntu下的curl命令你知道怎么用吗?

空扰寡人 提交于 2020-08-04 18:12:21

cURL(CommandLine Uniform Resource Locator)是一个利用URL语法在命令行下工作的文件传输工具,1997年首次发行。它支持文件上传和下载,所以是综合传输工具,但按传统,习惯称cURL为下载工具。cURL还包含了用于程序开发的libcurl。

curl命令参数很多,这里只列出我曾经用过、特别是在shell脚本中用到过的那些。
-v/--verbose 小写的v参数,用于打印更多信息,包括发送的请求信息,这在调试脚本是特别有用。
-m/--max-time <seconds> 指定处理的最大时长
-H/--header <header> 指定请求头参数
-s/--slient 减少输出的信息,比如进度
--connect-timeout <seconds> 指定尝试连接的最大时长
-x/--proxy <proxyhost[:port]> 指定代理服务器地址和端口,端口默认为1080
-T/--upload-file <file> 指定上传文件路径
-o/--output <file> 指定输出文件名称
-d/--data/--data-ascii <data> 指定POST的内容
--retry <num> 指定重试次数
-e/--referer <URL> 指定引用地址
-I/--head 仅返回头部信息,使用HEAD请求

1 get请求

   

curl http://www.baidu.com,回车之后,HTML内容打印在屏幕上;如果这里的URL指向的是一个文件或者一幅图都可以直接下载到本地。
curl -i "http://www.baidu.com" 显示全部信息
curl -l "http://www.baidu.com" 只显示头部信息
curl -v "http://www.baidu.com" 显示get请求全过程解析

 

2 下载请求

curl –o linjiqin http://www.cnblogs.com/X-knight/,执行后可以看到下载进度提示,完成100%后会自动退出了,把网页保存到X-knight中。
它还有一个大写O的选项,是按照服务器上的文件名保存到本地,如果执行 curl –O http://www.cnblogs.com ,是会报错的,提示找不到文件名,如果换成 curl –O https://www.cnblogs.com/X-knight/p/10589004.html ,就自动保存文件为 10589004 .html。

3 上传请求

     -T/--upload-file:往服务器上传文件

   上传多个文件

   curl -T "img[1-1000].png" ftp://example.com/upload/

   上传多个文件
   curl -T "{file1,file2}" http://www.example.com

POST方法

-d或--data参数:post请求,用法为:

1
curl -d "id=1&name=test" http://example.com/example.php ,需把请求的参数和URL分开,

 

--data-urlencode参数:可以自动转义成特殊字符,无需人工事先转义。

1
curl --data-urlencode "name=April 1" http://example.com/example.php

-F或--form:将本地文件上传到服务器,用法为:

1
curl -F "filename=@/home/test/test.pic" http://example.com/example.php 。千万不能漏掉@符号。

 

6、设置referer
有时候我们如果直接请求某个URL不能成功,它需要判断referer是否正确,那就可以通过-e或--referer参数模拟

1
curl --referer http://www.example.com http://www.example.com


7、指定User Agent
-A/--user-agent:伪装成指定的浏览器Chrome访问,用法:

1
curl -A "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36" www.baidu.com

  

8、伪造cookie
-b或--cookie:

有两种用法:

一是指定参数和值:

1
curl --cookie "name=xxx" http://www.example.com

二是从文件读取:

1
curl -b /cookie.txt http://www.example.com


9、保存cookie
-c/--cookie-jar:curl命令执行后保存操作时生成的cookie到文件:

1
curl -c ./cookie.txt -d username=aaaa -d pwd=****** http://www.example.com


10、定义输出显示内容
-w/--write-out: 可以定义输出的内容,如常用的http码,tcp连接时间,域名解析的时间,握手时间及第一时间响应时间等,非常强大。

1、打印出返回的http码

1
curl -o /dev/null -s -w %{http_code} "http://www.baidu.com"


2、打印响应时间

1
curl -o /dev/null -s -w "time_total: %{time_total}\n" "http://www.baidu.com"

 

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!