Linux下命令行cURL的10种常见用法示例
前言
在linux中curl是一个利用url规则在命令行下工作的文件传输工具,可以说是一款很强大的http命令行工具。它支持文件的上传和下载,是综合传输工具,但按传统,习惯称url为下载工具。
语法: # curl [option] [url]
本文主要跟大家分享了linux命令行curl的10种常见用法,分享出来供大家参考学习,下面来一起看看详细的介绍:
1. 获取页面内容
当我们不加任何选项使用 curl 时,默认会发送 get 请求来获取链接内容到标准输出。
curl http://www.codebelief.com
2. 显示 http 头
如果我们只想要显示 http 头,而不显示文件内容,可以使用 -i 选项:
curl -i http://www.codebelief.com
输出为:
http/1.1 200 ok server: nginx/1.10.3 date: thu, 11 may 2017 08:24:45 gmt content-type: text/html; charset=utf-8 content-length: 24206 connection: keep-alive x-powered-by: express cache-control: public, max-age=0 etag: w/"5e8e-yw5zdnvvly9/aenmx7fvxq" vary: accept-encoding
也可以同时显示 http 头和文件内容,使用 -i 选项:
curl -i http://www.codebelief.com
输出为:
http/1.1 200 ok server: nginx/1.10.3 date: thu, 11 may 2017 08:25:46 gmt content-type: text/html; charset=utf-8 content-length: 24206 connection: keep-alive x-powered-by: express cache-control: public, max-age=0 etag: w/"5e8e-yw5zdnvvly9/aenmx7fvxq" vary: accept-encoding <!doctype html> <html lang="en"> ...... </html>
3. 将链接保存到文件
我们可以使用 > 符号将输出重定向到本地文件中。
curl http://www.codebelief.com > index.html
也可以通过 curl 自带的 -o
/-o
选项将内容保存到文件中。
-
-o
(小写的 o):结果会被保存到命令行中提供的文件名 -
-o
(大写的 o):url 中的文件名会被用作保存输出的文件名
curl -o index.html http://www.codebelief.com curl -o http://www.codebelief.com/page/2/
注意:使用 -o
选项时,必须确保链接末尾包含文件名,否则 curl 无法正确保存文件。如果遇到链接中无文件名的情况,应该使
用 -o
选项手动指定文件名,或使用重定向符号。
4. 同时下载多个文件
我们可以使用 -o
或 -o
选项来同时指定多个链接,按照以下格式编写命令:
curl -o http://www.codebelief.com/page/2/ -o http://www.codebelief.com/page/3/
或者:
curl -o page1.html http://www.codebelief.com/page/1/ -o page2.html http://www.codebelief.com/page/2/
5. 使用 -l 跟随链接重定向
如果直接使用 curl 打开某些被重定向后的链接,这种情况下就无法获取我们想要的网页内容。例如:
curl http://codebelief.com
会得到如下提示:
<html> <head><title>301 moved permanently</title></head> <body bgcolor="white"> <center><h1>301 moved permanently</h1></center> <hr><center>nginx/1.10.3</center> </body> </html>
而当我们通过浏览器打开该链接时,会自动跳转到 http://www.codebelief.com。此时我们想要 curl 做的,就是像浏览器一样跟随链接的跳转,获取最终的网页内容。我们可以在命令中添加 -l 选项来跟随链接重定向:
curl -l http://codebelief.com
这样我们就能获取到经过重定向后的网页内容了。
6. 使用 -a 自定义 user-agent
我们可以使用 -a
来自定义用户代理,例如下面的命令将伪装成安卓火狐浏览器对网页进行请求:
curl -a "mozilla/5.0 (android; mobile; rv:35.0) gecko/35.0 firefox/35.0" http://www.baidu.com
下面我们会使用 -h 来实现同样的目的。
7. 使用 -h 自定义 header
当我们需要传递特定的 header 的时候,可以仿照以下命令来写:
curl -h "referer: www.example.com" -h "user-agent: custom-user-agent" http://www.baidu.com
可以看到,当我们使用 -h
来自定义 user-agent 时,需要使用 "user-agent: xxx
" 的格式。
我们能够直接在 header 中传递 cookie,格式与上面的例子一样:
curl -h "cookie: jsessionid=d0112a5063d938586b659ef8f939be24" http://www.example.com
另一种方式会在下面介绍。
8. 使用 -c 保存 cookie
当我们使用 curl 访问页面的时候,默认是不会保存 cookie 的。有些情况下我们希望保存 cookie 以便下次访问时使用。例如登陆了某个网站,我们希望再次访问该网站时保持登陆的状态,这时就可以现将登陆时的 cookie 保存起来,下次访问时再读取。
-c
后面跟上要保存的文件名。
curl -c "cookie-example" http://www.example.com
9. 使用 -b 读取 cookie
前面讲到了使用 -h
来发送 cookie 的方法,这种方式是直接将 cookie 字符串写在命令中。如果使用 -b 来自定义 cookie,命令如下:
curl -b "jsessionid=d0112a5063d938586b659ef8f939be24" http://www.example.com
如果要从文件中读取 cookie,-h 就无能为力了,此时可以使用 -b
来达到这一目的:
curl -b "cookie-example" http://www.example.com
即 -b
后面既可以是 cookie 字符串,也可以是保存了 cookie 的文件名。
10. 使用 -d 发送 post 请求
我们以登陆网页为例来进行说明使用 curl 发送 post 请求的方法。假设有一个登录页面 www.example.com/login,只需要提交用户名和密码便可登录。我们可以使用 curl 来完成这一 post 请求,-d 用于指定发送的数据,-x 用于指定发送数据的方式:
curl -d "username=tom&passwd=123456" -x post http://www.example.com/login
在使用 -d
的情况下,如果省略 -x
,则默认为 post 方式:
curl -d "username=tom&passwd=123456" http://www.example.com/login
强制使用 get 方式
发送数据时,不仅可以使用 post 方式,也可以使用 get 方式,例如:
curl -d "somedata" -x get http://www.example.com/api
或者使用 -g
选项:
curl -d "somedata" -g http://www.example.com/api
从文件中读取 data
curl -d "@data.txt" http://www.example.com/login
带 cookie 登录
当然,如果我们再次访问该网站,仍然会变成未登录的状态。我们可以用之前提到的方法保存 cookie,在每次访问网站时都带上该 cookie 以保持登录状态。
curl -c "cookie-login" -d "username=tom&passwd=123456" http://www.example.com/login
再次访问该网站时,使用以下命令:
curl -b "cookie-login" http://www.example.com/login
这样,就能保持访问的是登录后的页面了。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。