curl开发常用方法总结

curl开发常用方法总结

在开发中,后端与前端联调、后端与API联调,需要说明接口是否可用,千言万语,最好的方式就是丢给对方一个curl执行命令。

1、cURL 是什么?

cURL 是一个在命令行下使用的工具,用来:

  • 访问网站
  • 测试接口
  • 下载文件
  • 上传数据
2、cURL常用参数及说明
powershell 复制代码
-X, --request: 指定请求方法,如GET、POST、PUT、DELETE等。

-H, --header: 设置请求头,可以多次使用此参数来设置多个头信息。

-d, --data: 设置请求体数据,通常用于POST或PUT请求。默认情况下,使用此参数会使得请求方法为POST。

-F, --form: 用于模拟表单提交,可以上传文件等。

-G, --get: 将-d参数指定的数据作为URL的查询参数,强制使用GET请求。

-i, --include: 在输出中包含响应头。

-I, --head: 只获取响应头信息(HEAD请求)。

-k, --insecure: 允许不验证SSL证书。

-L, --location: 如果服务器返回重定向,自动跟随重定向。

-o, --output: 将响应输出到文件,而不是标准输出。

-O, --remote-name: 将输出保存为远程文件的文件名。

-s, --silent: 静默模式,不显示进度和错误信息。

-u, --user: 设置用户名和密码,用于服务器认证。

-v, --verbose: 显示更详细的信息,包括请求和响应的头信息等。

-A, --user-agent: 设置User-Agent头。

-b, --cookie: 设置Cookie。

-c, --cookie-jar: 将服务器返回的Cookie保存到文件。

--connect-timeout: 设置连接超时时间。

--max-time: 设置整个请求的最大时间。
3、cURL常见用法示例
powershell 复制代码
基本用法:获取网页内容
最简单的使用CURL的方式是直接输入URL,它会将获取的内容输出到标准输出。
示例:curl https://www.example.com

保存输出到文件
使用-o选项可以将输出保存到指定的文件。
示例:curl -o example.html https://www.example.com
这会将https://www.example.com的内容保存到example.html文件中。

跟随重定向
如果遇到重定向,可以使用-L选项让CURL跟随重定向。
示例:curl -L https://www.example.com

发送GET请求(默认)
CURL默认发送GET请求,但也可以显式指定-X GET。
示例:curl -X GET https://api.example.com/data

发送POST请求
使用-X POST可以发送POST请求,通常与-d选项一起使用来发送数据。
示例:curl -X POST -d "name=John&age=30" https://api.example.com/users
也可以发送JSON数据:
curl -X POST -H "Content-Type: application/json" -d '{"name":"John","age":30}' https://api.example.com/users

设置请求头
使用-H选项可以设置请求头。
示例:curl -H "Authorization: Bearer token123" https://api.example.com/protected

使用代理
使用-x选项可以指定代理服务器。
示例:curl -x http://proxy-server:port https://www.example.com

下载文件
使用-O选项可以下载文件并保留远程文件的文件名。
示例:curl -O https://www.example.com/file.zip

同时指定多个选项
可以组合多个选项,比如同时使用-H设置多个头,使用-d发送数据,使用-X指定方法等。
示例:curl -X PUT -H "Content-Type: application/json" -H "Authorization: Bearer token" -d '{"key":"value"}' https://api.example.com/resource

调试模式
使用-v选项可以启用详细模式,显示整个请求和响应的过程,便于调试。
示例:curl -v https://www.example.com

限制带宽
使用--limit-rate选项可以限制CURL使用的带宽。
示例:curl --limit-rate 100k -O https://www.example.com/largefile.zip

忽略SSL证书验证
使用-k选项可以忽略SSL证书验证(不推荐在生产环境使用,仅用于测试)。
示例:curl -k https://www.example.com

使用cookie
使用-b选项可以发送cookie,使用-c选项可以保存服务器返回的cookie。
示例:发送cookie:curl -b "name=value" https://www.example.com
保存cookie:curl -c cookies.txt https://www.example.com

使用用户认证
使用-u选项可以进行基本的HTTP认证。
示例:curl -u username:password https://www.example.com

上传文件
使用-T选项可以上传文件。
示例:curl -T localfile.txt ftp://ftp.example.com/upload/
4、cURL POST 请求示例

完整命令示例

powershell 复制代码
curl -X POST https://api.example.com/users \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9" \
  -d '{
    "name": "张三",
    "email": "zhangsan@example.com",
    "age": 28,
    "department": "技术部"
  }'

更简洁的写法

powershell 复制代码
curl -X POST https://api.example.com/users -H "Content-Type: application/json" -H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9" -d '{"name": "张三","email": "zhangsan@example.com","age": 28,"department": "技术部"}'

命令分解说明

部分 说明 示例
请求方法 -X POST 指定POST请求 -X POST
请求URL 接口地址 https://api.example.com/users
内容类型 -H "Content-Type: application/json" 声明发送JSON数据 -H "Content-Type: application/json"
认证头 -H "Authorization: ..." 携带访问令牌 -H "Authorization: Bearer ..."
请求体 -d '...' 包含实际的JSON数据 -d '{"name":"张三",...}'
相关推荐
逐梦吧!旅行者3 小时前
Linux MySQL 5.7用户管理与用户密码的设置问题
linux·mysql
RisunJan3 小时前
Linux命令-grpck命令(验证和修复组配置文件(`/etc/group` 和 `/etc/gshadow`)完整性的工具)
linux·运维·服务器
loosed3 小时前
Ubuntu mysql8 tar.xz 安装
linux·ubuntu·adb
Xの哲學4 小时前
Linux VxLAN深度解析: 从数据平面到内核实现的全面剖析
linux·服务器·算法·架构·边缘计算
添砖java‘’4 小时前
Linux信号机制详解:从产生到处理
linux·c++·操作系统·信号处理
MC皮蛋侠客4 小时前
Linux C++使用GDB调试动态库崩溃问题完全指南
linux·c++
Wang's Blog4 小时前
RabbitMQ: 消息发送、连接管理、消息封装与三种工程方案
linux·ubuntu·rabbitmq
Vect__5 小时前
初识操作系统
linux
若风的雨5 小时前
pcie bar 地址对齐规则
linux
CQ_YM5 小时前
Linux线程控制
linux·c语言·开发语言·线程