curl 使用:命令行中的 HTTP 客户端

简介: `curl` 是命令行神器,用于与服务器交互,支持HTTP、HTTPS、FTP等协议。本文教你如何用它做POST请求(-d/--data)、GET请求(-G/-d)、JSON请求(-H 'Content-Type: application/json')和文件上传(-F)。学会这些,轻松测试API、自动化任务。现在就动手试试吧!

在日常的软件开发和网络管理工作中,curl 是一个我们经常会使用到的命令行工具。它支持多种协议,包括 HTTP、HTTPS、FTP 等,用于发送和接收数据。

本文将通过简单易懂的语言,带你快速掌握 curl 在发送各种类型请求时的使用方法。

curl 基本概念

curl 是一个强大的命令行工具,用于在命令行或者脚本中与服务器交互。它支持多种协议,能够通过 URL 等参数发送请求,并获取或发送数据。适合用于测试 API、自动化任务、数据检索等场景。

发送 POST 请求

在使用 curl 发送 POST 请求时,常用 -d--data 参数来指定请求体的内容。

示例


# 发送 POST 请求,加入 -d 参数后,会自动转为 POST 方法,因此可以省略 -X POST 参数
curl -X POST www.baidu.com -d 'a=1&b=2'
# 或者直接使用 curl www.baidu.com -d 'a=1&b=2'

这里 -d 参数后跟着的是我们要发送的数据。这种方式简洁明了,非常适合测试简单的表单数据或 API 接口。

发送 GET 请求

发送 GET 请求时,我们可以通过在 URL 后直接加查询字符串或使用 -G 参数配合 -d 来构造查询字符串。

示例


# 发送 GET 请求,-G 参数用来构造 URL 的查询字符串
curl https://google.com/search  -G -d 'q=kitties&count=20'
# 或者直接使用完整的 URL
curl 'https://google.com/search?q=kitties&count=20'

这两种方式可以根据个人喜好和场景需求来选择使用,效果是相同的。

发送 JSON 请求

在现代的 Web 开发中,JSON 是最常见的数据交换格式之一。curl 通过 -H 参数添加 HTTP 头,其中 Content-Type: application/json 表明发送的数据类型为 JSON。

示例


curl -H 'Content-Type: application/json' -X POST https://api.weixin.qq.com/datacube/getweanalysisappiddailyvisittrend\?access_token\=ACCESS_TOKEN  -d '{
  "begin_date" : "20210328",
  "end_date" : "20210328"
}
'

这里使用 -H 添加了请求头,-X POST 指定了请求方法,虽然在这个场景下,由于使用了 -d 参数,-X POST 可以省略。

上传文件

curl 也支持文件上传功能,常通过 -F 参数实现。

示例


# 注意文件路径前需要加上 @ 符号
curl -X POST http://127.0.0.1:8000/upload/file  -F file=@/path/to/your/file/img1.jpeg -F type=1

在这个例子中,-F 参数指定了我们想要上传的文件,文件路径前必须加上 @ 符号,表示这后面是一个文件。

下载图片

使用 curl 可以方便地下载网络上的图片或文件:

示例

curl -X POST 'https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=abc' \
-H 'Content-Type: application/json' -H 'accept: image/jpeg' \
--data-raw '{
    "scene": "userId=2&activityId=5",
    "page": "pages/index/index"
}' > abc.jpeg

结语

通过这篇文章,相信你已经对 curl 的用法有了初步的了解。它是一个强大且灵活的工具,适用于多种场景。掌握了 curl,你便能在命令行下轻松与世界各地的服务器交流,实现数据的发送和接收。

不妨现在就开始尝试使用它,解锁更多可能吧!

相关文章
|
1月前
|
开发者 Python
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
71 1
|
2月前
|
Go 开发者
golang的http客户端封装
golang的http客户端封装
31 0
|
3月前
|
JSON 数据格式 Python
Python 的 requests 库是一个强大的 HTTP 客户端库,用于发送各种类型的 HTTP 请求
【6月更文挑战第15天】Python的requests库简化了HTTP请求。安装后,使用`requests.get()`发送GET请求,检查`status_code`为200表示成功。类似地,`requests.post()`用于POST请求,需提供JSON数据和`Content-Type`头。
50 6
|
3月前
|
Java
原生Feign使用详解(HTTP客户端)(二)
原生Feign使用详解(HTTP客户端)(二)
80 1
|
3月前
|
JSON Java API
原生Feign使用详解(HTTP客户端)(一)
原生Feign使用详解(HTTP客户端)(一)
155 1
|
3月前
|
数据采集 Java API
Java HTTP客户端工具的演变之路
Java HTTP客户端工具的演变之路
|
3月前
|
JSON 前端开发 JavaScript
Axios是一个基于Promise的HTTP客户端
Axios是一个基于Promise的HTTP客户端
27 0
|
3月前
|
JSON 安全 Java
JAVA Socket 实现HTTP与HTTPS客户端发送POST与GET方式请求
JAVA Socket 实现HTTP与HTTPS客户端发送POST与GET方式请求
53 0
|
存储 Web App开发 监控
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
我们以前使用过的对hbase和hdfs进行健康检查,及剩余hdfs容量告警,简单易用 1.针对hadoop2的脚本: #/bin/bashbin=`dirname $0`bin=`cd $bin;pwd`STATE_OK=...
1040 0
|
Web App开发 存储 前端开发
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
      前段时间公司hadoop集群宕机,发现是namenode磁盘满了, 清理出部分空间后,重启集群时,重启失败。 又发现集群Secondary namenode 服务也恰恰坏掉,导致所有的操作log持续写入edits.new 文件,等集群宕机的时候文件大小已经达到了丧心病狂的70G+..重启集群报错 加载edits文件失败。
897 0

热门文章

最新文章