网站首页 > 博客文章 正文
cURL(Client URL)是一个功能强大的命令行工具,用于在终端中传输数据。它支持多种协议,包括 HTTP、HTTPS、FTP、FTPS、SCP、SFTP、SMTP 等。以下是 cURL 的详细用法指南。
基础语法
curl [options] [URL]
基本用法
1. 获取网页内容
最简单的用法是直接获取一个 URL 的内容:
curl https://example.com
2. 保存输出到文件
# 使用 -o 参数指定输出文件名
curl -o filename.html https://example.com
# 使用 > 重定向符
curl https://example.com > filename.html
# 使用 -O 参数保留远程文件名
curl -O https://example.com/filename.txt
3. 下载多个文件
curl -O https://example.com/file1.txt -O https://example.com/file2.txt
HTTP 请求相关
1. 指定 HTTP 方法
# GET 请求(默认)
curl https://api.example.com/data
# POST 请求
curl -X POST https://api.example.com/data
# PUT 请求
curl -X PUT https://api.example.com/data
# DELETE 请求
curl -X DELETE https://api.example.com/data
2. 发送表单数据
# 发送 URL 编码的表单数据
curl -d "name=John&age=25" https://api.example.com/form
# 发送文件中的表单数据
curl -d @data.txt https://api.example.com/form
3. 发送 JSON 数据
curl -X POST -H "Content-Type: application/json" -d '{"name":"John","age":25}' https://api.example.com/json
# 从文件发送 JSON 数据
curl -X POST -H "Content-Type: application/json" -d @data.json https://api.example.com/json
4. 设置请求头
curl -H "Authorization: Bearer token123" https://api.example.com
curl -H "Content-Type: application/json" -H "Accept: application/json" https://api.example.com
5. 处理重定向
# 允许重定向
curl -L https://example.com
# 显示重定向过程
curl -L -v https://example.com
认证相关
1. 基本认证
curl -u username:password https://api.example.com
# 或者
curl --user username:password https://api.example.com
2. Bearer Token 认证
curl -H "Authorization: Bearer YOUR_ACCESS_TOKEN" https://api.example.com
3. 客户端证书认证
curl --cert client.pem --key key.pem https://api.example.com
Cookie 和 Session 相关
1. 发送 Cookie
curl -b "name=value" https://example.com
curl --cookie "name=value" https://example.com
2. 保存和使用 Cookie
# 保存 Cookie 到文件
curl -c cookies.txt https://example.com
# 使用已保存的 Cookie
curl -b cookies.txt https://example.com
调试和输出控制
1. 详细输出
curl -v https://example.com
curl --verbose https://example.com
2. 只显示响应头
curl -I https://example.com
curl --head https://example.com
3. 隐藏进度信息
curl -s https://example.com
curl --silent https://example.com
4. 显示响应时间
curl -w "Total time: %{time_total}s\n" https://example.com
高级选项
1. 限制传输速率
# 限制下载速率为 1000 字节/秒
curl --limit-rate 1000B https://example.com/largefile.zip
2. 设置超时
# 设置连接超时为 10 秒
curl --connect-timeout 10 https://example.com
# 设置总传输超时为 30 秒
curl --max-time 30 https://example.com
3. 使用代理
curl -x proxy.example.com:8080 https://example.com
curl --proxy proxy.example.com:8080 https://example.com
# 使用 SOCKS5 代理
curl --socks5 proxy.example.com:1080 https://example.com
4. 恢复下载
curl -C - -O https://example.com/largefile.zip
5. 发送 HTTP/2 请求
curl --http2 https://example.com
实际 API 调用示例
调用 DeepSeek FIM 补全 API 的例子
curl -X POST https://api.deepseek.com/beta/completions \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-H "Authorization: Bearer YOUR_API_KEY" \
-d '{
"model": "deepseek-chat",
"prompt": "def fibonacci(n):",
"suffix": " return result",
"max_tokens": 128,
"temperature": 0.7
}'
常见选项参考表
选项长选项描述
-A--user-agent设置用户代理
-b--cookie发送 Cookie
-c--cookie-jar保存 Cookie 到文件
-d--data发送 POST 数据
-F--form发送多部分表单数据
-H--header设置请求头
-I--head只获取响应头
-k--insecure允许不安全的 SSL 连接
-L--location跟随重定向
-o--output将输出保存到文件
-O--remote-name使用远程文件名保存
-s--silent静默模式
-T--upload-file上传文件
-u--user用户名和密码
-v--verbose详细输出
-X--request指定请求方法
-x--proxy使用代理
cURL 是一个非常强大的工具,掌握它可以极大地提高在命令行环境下与 API 交互和数据传输的效率。
猜你喜欢
- 2025-05-21 上传图片到cloudflare r2
- 2025-05-21 wordpress通过代码实现百度主动推送和实时推送
- 2025-05-21 百度实时推送代码解决方案
- 2025-05-21 Elasticsearch的路由routing的应用技巧
- 2025-05-21 技巧:PHP版本怎样隐藏在Linux服务器
- 2025-05-21 Python 进阶-day24: API 开发
- 2025-05-21 kubectl常用删除命令
- 2025-05-21 HTTP 的常见头字段有哪些?说说它们的作用
- 2025-05-21 网络编程神器:让你的网络编程不再踩坑
- 2025-05-21 HTTP/HTTPS协议基础
你 发表评论:
欢迎- 377℃手把手教程「JavaWeb」优雅的SpringMvc+Mybatis整合之路
- 373℃用AI Agent治理微服务的复杂性问题|QCon
- 364℃初次使用IntelliJ IDEA新建Maven项目
- 357℃Maven技术方案最全手册(mavena)
- 353℃安利Touch Bar 专属应用,让闲置的Touch Bar活跃起来!
- 352℃IntelliJ IDEA 2018版本和2022版本创建 Maven 项目对比
- 351℃InfoQ 2024 年趋势报告:架构篇(infoq+2024+年趋势报告:架构篇分析)
- 349℃IT全明星|IntelliJ IDEA学习笔记(四、idea中怎么创建maven项目)
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)