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":"张三",...}'
相关推荐
遇见火星9 小时前
Linux 运维:删除大日志文件时避免磁盘 IO 飙升,echo 空文件 vs truncate 命令对比实操
linux·运维·服务器
食咗未9 小时前
Linux SPI接口显示屏调试过程记录
linux
A-花开堪折9 小时前
Qemu-NUC980(十一):SPI Controller
linux·arm开发·驱动开发·嵌入式硬件
RisunJan9 小时前
Linux命令-ipcrm命令(删除Linux系统中的进程间通信(IPC)资源)
linux·运维·服务器
Joren的学习记录9 小时前
【Linux运维大神系列】Kubernetes详解2(kubeadm部署k8s1.27单节点集群)
linux·运维·kubernetes
lbb 小魔仙9 小时前
【Linux】K8s 集群搭建避坑指南:基于 Linux 内核参数调优的生产级部署方案
linux·运维·kubernetes
老兵发新帖9 小时前
ubuntu服务器配置私钥登录
linux·服务器·ubuntu
vortex59 小时前
Linux 用户组查询命令详解
linux·运维·服务器
小杜今天学AI了吗9 小时前
如何配置 linux 系统的conda 环境
linux·运维·conda
oMcLin9 小时前
如何在Ubuntu 22.04 LTS上通过配置ZFS存储池,提升高吞吐量数据库的读写性能与可靠性?
linux·数据库·ubuntu