文件传输工具Linux curl命令详解
一 curl命令介绍
在Linux中curl是一个利用URL规则在命令行下工作的文件传输工具,可以说是一款很强大的http命令行工具。它支持文件的上传和下载,是综合传输工具,但按传统,习惯称url为下载工具。
语法:# curl [option] [url]
data:image/s3,"s3://crabby-images/5f8b3/5f8b3769c21b45b9e89083f9384531a9d2f2f823" alt=""
二 常见参数:
-A/--user-agent <string> 设置用户代理发送给服务器
-b/--cookie <name=string/file> cookie字符串或文件读取位置
-c/--cookie-jar <file> 操作结束后把cookie写入到这个文件中-C/--continue-at <offset> 断点续转
-D/--dump-header <file> 把header信息写入到该文件中
-e/--referer 来源网址
-f/--fail 连接失败时不显示http错误-o/--output 把输出写到该文件中
-O/--remote-name 把输出写到该文件中,保留远程文件的文件名-r/--range <range> 检索来自HTTP/1.1或FTP服务器字节范围-s/--silent 静音模式。不输出任何东西
-T/--upload-file <file> 上传文件-u/--user <user[:password]> 设置服务器的用户和密码-w/--write-out [format] 什么输出完成后
-x/--proxy <host[:port]> 在给定的端口上使用HTTP代理
-#/--progress-bar 进度条显示当前的传送状态
后面还有很多选项,只截取开头部分
data:image/s3,"s3://crabby-images/4741a/4741a337854ddc62fbb35f73769e0b10ee6b9b8c" alt=""
三 curl应用案例
1 基本用法
# curl http://www.linux.com
执行后,www.linux.com 的html就会显示在屏幕上了
data:image/s3,"s3://crabby-images/33158/33158389b18169e67e787dbb037b8e7a1f5e459a" alt=""
Ps:由于安装linux的时候很多时候是没有安装桌面的,也意味着没有浏览器,因此这个方法也经常用于测试一台服务器是否可以到达一个网站
2 保存访问的网页
2.1 使用linux的重定向功能保存
# curl http://www.linux.com >> linux.html
data:image/s3,"s3://crabby-images/ed854/ed85490086b9a0c014ebfefd79985ce700ad0bba" alt=""
data:image/s3,"s3://crabby-images/5392b/5392b8dc68bcd7783566b1bb5b53ac19cf5a5139" alt=""
2.2 可以使用curl的内置option:-o(小写)保存网页
$ curl -o linux.html http://www.linux.com
执行完成后会显示如下界面,显示100%则表示保存成功
2.3 可以使用curl的内置option:-O(大写)保存网页中的文件
要注意这里后面的url要具体到某个文件,不然抓不下来
# curl -O http://www.linux.com/hello.sh
data:image/s3,"s3://crabby-images/6cc17/6cc17639cf3fa6719bdc6c5056ccde3cb910381d" alt=""
data:image/s3,"s3://crabby-images/e017e/e017ed645423107f4f78e5332dd09059c5d8946f" alt=""
3 测试网页返回值
# curl -o /dev/null -s -w %{http_code} www.linux.com
data:image/s3,"s3://crabby-images/0289a/0289a6839dd53a5eafbf12cd747d632a825a6be2" alt=""
Ps:在脚本中,这是很常见的测试网站是否正常的用法
4 指定proxy服务器以及其端口
很多时候上网需要用到代理服务器(比如是使用代理服务器上网或者因为使用curl别人网站而被别人屏蔽IP地址的时候),幸运的是curl通过使用内置option:-x来支持设置代理
# curl -x 192.168.100.100:1080 http://www.linux.com
这里因为没有搭建在本地的网站,所以访问不到
data:image/s3,"s3://crabby-images/1d249/1d24940aaeb64f45d379e0340526f5f9877832f3" alt=""
5 cookie
有些网站是使用cookie来记录session信息。对于chrome这样的浏览器,可以轻易处理cookie信息,但在curl中只要增加相关参数也是可以很容易的处理cookie
5.1 保存http的response里面的cookie信息。内置option:-c(小写)
# curl -c cookiec.txt http://www.linux.com
执行后cookie信息就被存到了cookiec.txt里面了
data:image/s3,"s3://crabby-images/53152/53152fc9d732e92626f5a2f6da042a91ae2ef70a" alt=""
5.2 保存http的response里面的header信息。内置option: -D
# curl -D cookied.txt http://www.linux.com
执行后cookie信息就被存到了cookied.txt里面了
data:image/s3,"s3://crabby-images/0cdbf/0cdbff9f39a766f6fe80b8b5a80a356a051d5dbf" alt=""
data:image/s3,"s3://crabby-images/01ced/01cedf09464f411d54c36c3beca030baa9c34d3f" alt=""
注意:-c(小写)产生的cookie和-D里面的cookie是不一样的。
5.3 使用cookie
很多网站都是通过监视你的cookie信息来判断你是否按规矩访问他们的网站的,因此我们需要使用保存的cookie信息。内置option: -b
# curl -b cookiec.txt http://www.linux.com
data:image/s3,"s3://crabby-images/5f866/5f866c68e377a0eb18d40950f305dd6c0cd5262b" alt=""
6 模仿浏览器
有些网站需要使用特定的浏览器去访问他们,有些还需要使用某些特定的版本。curl内置option:-A可以让我们指定浏览器去访问网站
# curl -A "Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.0)" http://www.linux.com
data:image/s3,"s3://crabby-images/d7ef7/d7ef74ede04f1756380989ea12f72d9499c11e40" alt=""
这样服务器端就会认为是使用IE8.0去访问的
7 下载文件
7.1 利用curl下载文件
#使用内置option:-o(小写)
#curl -o test.jpg https://www.runoob.com/wp-content/uploads/2016/04/docker01.png
data:image/s3,"s3://crabby-images/6b0a0/6b0a02d47163cf7896b2c7024ff3f41f29911941" alt=""
data:image/s3,"s3://crabby-images/104be/104be4b3ccb84d20b8beafaa47c91c8f99e001da" alt=""
#使用内置option:-O(大写)
# curl -O http://www.linux.com/haha.JPG
data:image/s3,"s3://crabby-images/1d3df/1d3dfec05a9f21119fa14b03934851e9268df88f" alt=""
这样就会以服务器上的名称保存文件到本地
7.2 循环下载
有时候下载图片可以能是前面的部分名称是一样的,就最后的尾椎名不一样
# curl -O http://www.linux.com/haha[1-5].JPG
这样就会把haha1,haha2,haha3,haha4,haha5全部保存下来
这里没有合适的服务器资源,就不演示了
7.3 显示下载进度条
# curl -# -O https://www.runoob.com/wp-content/uploads/2016/04/docker01.png
data:image/s3,"s3://crabby-images/c86af/c86af73c50062e7373b017cfddb697bb13fed263" alt=""
8.5 不会显示下载进度信息
curl -s -O https://www.runoob.com/wp-content/uploads/2016/04/docker01.png
data:image/s3,"s3://crabby-images/6cc2b/6cc2b823235cf858a9721dcacee34ac2268894d0" alt=""
9 上传文件
curl不仅仅可以下载文件,还可以上传文件。通过内置option:-T来实现
# curl -T haha.JPG -u 用户名:密码 ftp://www.linux.com/img/
这样就向ftp服务器上传了文件haha.JPG , 没有搭建本地ftp服务器,这里不演示了
相关推荐
-
PHP8种变量类型的详细讲解2025-02-22 00:32:24
-
php+apache 和 php+nginx的区别2025-02-22 00:21:27
-
PHP:与workerman结合实现定时任务2025-02-22 00:15:57
-
Nginx的Rewrite规则与实例2025-02-22 00:15:39
-
MySql中身份证字段的简单脱敏介绍2025-02-22 00:15:36