首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >linux之curl命令

linux之curl命令

原创
作者头像
入门笔记
发布于 2022-05-24 13:24:53
发布于 2022-05-24 13:24:53
3.8K0
举报
文章被收录于专栏:入门小站入门小站

curl命令 是一个利用URL规则在命令行下工作的文件传输工具。它支持文件的上传和下载,所以是综合传输工具,但按传统,习惯称curl为下载工具。作为一款强力工具,curl支持包括HTTP、HTTPS、ftp等众多协议,还支持POST、cookies、认证、从指定偏移处下载部分文件、用户代理字符串、限速、文件大小、进度条等特征。

命令语法

代码语言:txt
AI代码解释
复制
> curl (选项)(参数)

命令选项

代码语言:txt
AI代码解释
复制
-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                        进度条显示当前的传送状态

文件下载

  • curl命令可以用来执行下载、发送各种HTTP请求,指定HTTP头部等操作
  • curl是将下载文件输出到stdout,将进度信息输出到stderr,不显示进度信息使用--silent选项。
代码语言:txt
AI代码解释
复制
> curl https://rumenz.com --silent

下载文件到指定的文件小写-o,大写-O 保存文件和它的原始文件名

代码语言:txt
AI代码解释
复制
> curl https://rumenz.com/1.html -o 2.html

大写-O 保存文件和它的原始文件名

代码语言:txt
AI代码解释
复制
> curl https://rumenz.com/1.html -O

--progress显示进度条

代码语言:txt
AI代码解释
复制
> curl https://rumenz.com/2.html -o 2.html --progress

断点续传

代码语言:txt
AI代码解释
复制
> curl -O -u 'rumenz':'test' ftp://rumenz.com/jdk.tar.gz

然后你的连接突然断开,你可以用以下命令继续下载curl -C - -O -u 'rumenz':'test' ftp://rumenz.com/jdk.tar.gz

注意断点续传的参数是-C, 要自动续传的话要使用 -C -, 否则需要手工指定断点的字节位置.

伪造请求来源

代码语言:txt
AI代码解释
复制
> curl -e https://json.im https://rumenz.com

参照页是位于HTTP头部中的一个字符串,用来表示用户是从哪个页面到达当前页面的,如果用户点击网页A中的某个连接,那么用户就会跳转到B网页,网页B头部的参照页字符串就包含网页A的URL。也可以使用--referer选项指定参照页字符串.

-H参数可以通过直接添加标头 Referer,达到同样效果

代码语言:txt
AI代码解释
复制
> curl -H 'Referer: https://json.im' https://rumenz.com

设置请求header

代码语言:txt
AI代码解释
复制
> curl -H "Host:rumenz.com" -H "accept-language:zh-cn" URL

curl的带宽控制

代码语言:txt
AI代码解释
复制
> curl --limit-rate 200k  https://rumenz.com/1.html

用curl进行认证

使用curl选项 -u 可以完成HTTP或者FTP的认证,可以指定密码,也可以不指定密码在后续操作中输入密码:

代码语言:txt
AI代码解释
复制
> curl -u user:pwd https://rumenz.com
> curl -u user https://rumenz.com

只打印响应头

代码语言:txt
AI代码解释
复制
> curl -I https://rumenz.com
HTTP/1.1 200 OK
Server: openresty/1.19.3.1
Date: Wed, 02 Jun 2021 13:37:41 GMT
Content-Type: text/html; charset=utf-8
Connection: keep-alive

使用curl模拟get请求

直接显示网页内容

代码语言:txt
AI代码解释
复制
> curl https://json.im/1.txt
123
456

显示请求头和网页内容

代码语言:txt
AI代码解释
复制
> curl -i https://json.im/1.txt
HTTP/1.1 200 OK
Server: openresty
Date: Wed, 02 Jun 2021 14:02:30 GMT
Content-Type: text/plain
Content-Length: 8
Last-Modified: Wed, 02 Jun 2021 14:00:57 GMT
Connection: keep-alive
ETag: "60b78f19-8"
Accept-Ranges: bytes

123
456

直接显示网页内容

代码语言:txt
AI代码解释
复制
> curl -l https://json.im/1.txt

显示get请求全过程解析

代码语言:txt
AI代码解释
复制
> curl -v https://json.im/1.txt

·

使用curl模拟post请求

代码语言:txt
AI代码解释
复制
> curl -d "param1=value1&param2=value2" https://json.im/login
> curl -d'login=rumenz&password=123' -X POST https://json.im/login
> curl -d 'login=rumenz' -d 'password=123' -X POST  https://json.im/login

--data-urlencode 参数等同于-d,发送 POST请求的数据体,区别在于会自动将发送的数据进行 URL 编码.

代码语言:txt
AI代码解释
复制
> curl --data-urlencode 'comment=hello world' https://json.im/login

上传文本文件

代码语言:txt
AI代码解释
复制
> curl -d '@data.txt' https://json.im/upload

post json格式的数据

代码语言:txt
AI代码解释
复制
> curl -l -H 'Content-type: application/json' -X POST -d '{"rumenz":"123"}' https://json.im/123.json

向服务器发送 Cookie

代码语言:txt
AI代码解释
复制
> curl https://json.im --cookie "user=rumenz&pass=123456"

Cookie写入到一个文件

代码语言:txt
AI代码解释
复制
> curl -c cookies.txt https://json.im

上传二进制文件

-F参数用来向服务器上传二进制文件。

代码语言:txt
AI代码解释
复制
> curl -F "file=@123.png" https://json.im/uploadfile

上面命令会给 HTTP 请求加上标头 Content-Type: multipart/form-data ,然后将文件123..png作为file字段上传。

-F 参数可以指定MIME 类型。

代码语言:txt
AI代码解释
复制
> curl -F 'file=@123.png;type=image/png'  https://json.im/uploadfile

上面命令指定 MIME 类型为image/png,否则 curl 会把 MIME 类型设为 application/octet-stream。

-F参数也可以指定文件名。

代码语言:txt
AI代码解释
复制
> curl -F 'file=@123.png;filename=rumenz.png' https://json.im/uploadfile 

上面命令中,原始文件名为123.png,但是服务器接收到的文件名为rumenz.png

请求跟随服务器的重定向

-L参数会让 HTTP 请求跟随服务器的重定向。curl 默认不跟随重定向。

代码语言:txt
AI代码解释
复制
> curl -L -d 'rumenz=123' https://json.im/

调试参数

-v 参数输出通信的整个过程,用于调试。

代码语言:txt
AI代码解释
复制
> curl -v https://json.im/1.txt
*   Trying 150.109.147.28...
* TCP_NODELAY set
* Connected to json.im (150.109.147.28) port 443 (#0)
* ALPN, offering h2
* ALPN, offering http/1.1
* Cipher selection: ALL:!EXPORT:!EXPORT40:!EXPORT56:!aNULL:!LOW:!RC4:@STRENGTH
* successfully set certificate verify locations:
*   CAfile: /etc/ssl/cert.pem
  CApath: none
* TLSv1.2 (OUT), TLS handshake, Client hello (1):
* TLSv1.2 (IN), TLS handshake, Server hello (2):
* TLSv1.2 (IN), TLS handshake, Certificate (11):
* TLSv1.2 (IN), TLS handshake, Server key exchange (12):
* TLSv1.2 (IN), TLS handshake, Server finished (14):
* TLSv1.2 (OUT), TLS handshake, Client key exchange (16):
* TLSv1.2 (OUT), TLS change cipher, Client hello (1):
* TLSv1.2 (OUT), TLS handshake, Finished (20):
* TLSv1.2 (IN), TLS change cipher, Client hello (1):
* TLSv1.2 (IN), TLS handshake, Finished (20):
* SSL connection using TLSv1.2 / ECDHE-RSA-AES128-GCM-SHA256
* ALPN, server accepted to use http/1.1
* Server certificate:
*  subject: CN=json.im
*  start date: Apr 27 14:50:23 2021 GMT
*  expire date: Jul 26 14:50:23 2021 GMT
*  subjectAltName: host "json.im" matched cert's "json.im"
*  issuer: C=US; O=Let's Encrypt; CN=R3
*  SSL certificate verify ok.
> GET /1.txt HTTP/1.1
> Host: json.im
> User-Agent: curl/7.54.0
> Accept: */*
>
< HTTP/1.1 200 OK
< Server: openresty
< Date: Wed, 02 Jun 2021 14:31:36 GMT
< Content-Type: text/plain
< Content-Length: 8
< Last-Modified: Wed, 02 Jun 2021 14:00:57 GMT
< Connection: keep-alive
< ETag: "60b78f19-8"
< Accept-Ranges: bytes
<
123
456
* Connection #0 to host json.im left intact

--trace参数也可以用于调试,还会输出原始的二进制数据。

代码语言:txt
AI代码解释
复制
> curl --trace - https://json.im

原文链接:https://rumenz.com/rumenbiji/linux-curl.html

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》070-商业项目:电商后台管理系统实战(商品管理模块的开发)
在电商平台中,商品管理模块是连接商家与消费者的重要桥梁。它不仅承担着商品信息的录入、修改与删除等基本功能,还涉及到库存管理、价格调整、上下架操作等多项关键任务。一个高效的商品管理模块能够帮助商家轻松管理各种商品,提高销售效率,并确保用户获得准确的信息。
愚公搬代码
2025/06/03
2040
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》070-商业项目:电商后台管理系统实战(商品管理模块的开发)
一个后端狗的 Vue 笔记【入门级】
最近找了些教程,顺带着趴在官网上,看了看 Vue 的一些内容,入门的一些概念,以及基础语法,还有一些常用的操作,瞄了一眼,通篇文字+贴了部分代码 9000 多字,入门语法什么的还是很好理解的,以前也有一定做小程序的基础,感觉还是很相似的,不过对于一些稍复杂的点,感觉还是总结的不够细致,例如插槽,和计算属性等,平时前端的东西看的也不是很多,学习过程中整理的笔记,和大家一起分享交流!欢迎各位大大交流意见~
BWH_Steven
2020/09/10
1.4K0
一个后端狗的 Vue 笔记【入门级】
【前端面考面试官系列】入门Vue全家桶
达达回答:Vue的安装可以从两个方面进行安装,第一种是CDN引入,第二种是NPM安装。
达达前端
2020/02/18
9090
【前端面考面试官系列】入门Vue全家桶
VUE Cookbook 系列:实现可配置组合表单
本案例将会讲解如何使用 vue.js + ElementUI 开发一个简单的 可配置组合表单 Demo。
IMWeb前端团队
2019/12/03
1K0
React、Vue3、Svelte 写法大 PK
本文将会从响应式、模板、生命周期、组件、表单、网络请求等几个方面,来对比 React、Vue3、Svelte 三大流行组件的用法区别。
ConardLi
2023/08/23
4461
React、Vue3、Svelte 写法大 PK
9个Vue开发技巧助力成为更好的工程师
原文链接:https://juejin.im/post/5e8a9b1ae51d45470720bdfa
歪马
2020/04/16
4.3K0
4. 许愿墙后台管理系统(前端页面)
许愿墙的后台管理系统主要有4个模块:登录模块、首页模块、许愿管理模块和管理员管理模块。使用前后端分离方式,后端接口使用Express框架,前端使用Vue框架,页面使用Element组件。这节实现前端页面。
爱学习的程序媛
2022/04/07
1K0
4. 许愿墙后台管理系统(前端页面)
6. Element Plus前端组件库
Element-UI 是基于 Vue 开发的一套UI组件库,提供丰富网页开发的组件,可快速开发网站,降低前端开发成本。
alexhuiwang
2023/04/24
5.7K0
6. Element Plus前端组件库
0基础菜鸟学前端之Vue.js
  简介:0基础前端菜鸟,啃了将近半月前端VUE框架,对前端知识有了初步的了解。下面总结一下这段时间的学习心得。 文章结构 前端基础 Vue.js简介 Vue.js常用指令 Vue.js组件 Vue
互联网金融打杂
2018/04/03
4.5K0
0基础菜鸟学前端之Vue.js
10 个 Vue 开发技巧,助力成为更好的工程师!
在组件中使用 $route 会使之与其对应路由形成高度耦合,从而使组件只能在某些特定的 URL 上使用,限制了其灵活性。
逆锋起笔
2020/06/17
1.9K0
【前端大神面考面试官系列】入门Vue全家桶
达达回答:Vue的安装可以从两个方面进行安装,第一种是CDN引入,第二种是NPM安装。
达达前端
2022/04/13
1.3K0
【前端大神面考面试官系列】入门Vue全家桶
vue学习笔记-day03
语法:array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
全栈程序员站长
2022/06/30
8920
vue学习笔记-day03
vue.js学习之入门实例
之前一直看过vue.js官网api,但是很少实践,这里抽出时间谢了个入门级的demo,记录下一些知识点,防止后续踩坑,牵扯到的的知识点:vue、vue-cli、vue-router、webpack等。
用户1141560
2017/12/26
1.5K0
vue.js学习之入门实例
【架构师(第二十五篇)】编辑器开发之属性编辑区域表单渲染
---- 更新属性的过程 点击某一个组件,选中组件 将它的属性以不同类型的表单呈现在右侧区域 编辑表单中的值,在值更新的同时,将数据更新到界面 获取正在编辑的元素的属性 组件外套一层 wrapper 用来隔离点击事件和组件自身行为 鼠标经过组件添加边框样式 点击某一个组件,选中组件,选中的组件添加高亮样式 点击某一个组件,向父组件 Editor.vue 发射 setActive 事件 Editor.vue 通过 commit 更新 store 中的状态 store 中接收组件 id,计算当前组件的属性 E
一尾流莺
2022/12/10
7610
【架构师(第二十五篇)】编辑器开发之属性编辑区域表单渲染
一篇文章,Vue快速入门!!!
MVVM源自于经典的MVC(Model-View-Controller)模式。MVVM的核心是ViewModel层,负责转换Model中的数据对象来让数据变得更容易管理和使用。其作用如下:
全栈程序员站长
2022/08/19
2K0
一篇文章,Vue快速入门!!!
【一起来烧脑】一步学会Vue.js系统
Vuejs是一个构建数据驱动的web界面的库,通过api实现响应的数据绑定和组合的视图组件,Vue.js的核心是一个响应的数据绑定系统,它让数据与DOM保持同步非常简单,一旦创建了绑定,DOM 将与数据保持同步。
达达前端
2019/07/18
1.4K0
【一起来烧脑】一步学会Vue.js系统
前端MVC Vue2学习总结(五)——表单输入绑定、组件
一、表单输入绑定 1.1、基础用法 你可以用 v-model 指令在表单控件元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇,但 v-model 本质上不过是语法糖,它负责监听用户的输入事件以更新数据,并特别处理一些极端的例子。 v-model 并不关心表单控件初始化所生成的值。因为它会选择 Vue 实例数据来作为具体的值。 1.1.1、文本 <input v-model="message" placeholder="edit me"> <p>Message is: {{
张果
2018/03/30
3.6K0
前端MVC Vue2学习总结(五)——表单输入绑定、组件
重学巩固你的Vuejs知识(上)
https://github.com/webVueBlog/interview-answe/issues/156
达达前端
2020/10/28
3.9K0
VUE2全家桶精讲
概念:Vue (读音 /vjuː/,类似于 view) 是一套构建用户界面的渐进式框架。
HelloWorldZ
2024/03/20
9730
VUE2全家桶精讲
TienChin 渠道管理-前端展示渠道信息
在编写 Vue 项目的时候我们可以使用 IDEA 当中提供的一个工具叫做 structure,也就是说可以很轻松的列举出当前 Vue 文件的大致结构,点那个就会跳转到对应的地方。
程序员NEO
2023/10/12
3920
TienChin 渠道管理-前端展示渠道信息
相关推荐
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》070-商业项目:电商后台管理系统实战(商品管理模块的开发)
更多 >
LV.0
这个人很懒,什么都没有留下~
目录
  • 命令语法
  • 命令选项
  • 文件下载
  • 下载文件到指定的文件小写-o,大写-O 保存文件和它的原始文件名
  • 断点续传
  • 伪造请求来源
  • 设置请求header
  • curl的带宽控制
  • 用curl进行认证
  • 只打印响应头
  • 使用curl模拟get请求
  • 使用curl模拟post请求
  • 上传文本文件
  • post json格式的数据
  • 向服务器发送 Cookie
  • Cookie写入到一个文件
  • 上传二进制文件
  • 请求跟随服务器的重定向
  • 调试参数
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档