当前位置: 首页 > news >正文

curl 学习

curl是一个功能强大的命令行工具,用于通过多种网络协议(主要是 HTTP、HTTPS)进行数据传输。它的名字意为“Client URL”,是开发者和系统管理员最常用的工具之一。

主要功能和特点

一.支持多种协议

  • HTTP/HTTPS

  • FTP/FTPS

  • SCP/SFTP

  • LDAP

  • POP3/IMAP/SMTP

  • 等等(共支持 20+ 种协议)

二.核心功能

  • 发送 HTTP 请求(GET、POST、PUT、DELETE 等)

  • 文件上传和下载

  • 支持 SSL/TLS 加密

  • 支持代理

  • 用户认证(Basic、Digest、Bearer Token 等)

  • cookie 支持

  • 跟随重定向

  • 限速控制

  • 断点续传

安装

大多数 Linux 发行版和 macOS 已预装curl。若未安装:

Ubuntu/Debian:

sudo apt install curl

CentOS/RHEL:

sudo yum install curl

macOS(通过 Homebrew):

brew install curl

基本用法示例

一、基本语法

curl [选项] [URL]
1. 简单 GET 请求
curl https://httpbin.org/get
2. 带请求头的 GET
curl -H "Authorization: Bearer your-token" https://api.example.com/data
3. POST 请求(表单格式)
curl -X POST -d "name=alice&age=30" https://httpbin.org/post
4. POST JSON 数据
curl -X POST -H "Content-Type: application/json" -d '{"name":"zhangsan","age":30}' https://httpbin.org/post
5. 下载文件
# 保存为 file.pdf curl -O https://example.com/file.pdf # 保存为 mydoc.pdf curl -o mydoc.pdf https://example.com/file.pdf
6. 跟随重定向
curl -L http://example.com
7. 使用 Basic 认证
curl -u username:password https://secure.example.com
8. 查看完整请求/响应(调试)
curl -v https://httpbin.org/get

二、常用选项(Options)

选项说明
-X--request指定请求方法(如 GET、POST、PUT、DELETE)
-H--header添加自定义请求头
-d--data发送 POST 数据(默认使用 application/x-www-form-urlencoded)
-o--output将响应保存到指定文件
-O--remote-name使用远程文件名保存下载内容
-L--location自动跟随重定向
-v--verbose显示详细请求/响应过程(用于调试)
-s--silent静默模式,不显示进度条或错误信息
-i--include在输出中包含响应头
-u--user提供用户名和密码用于认证(如 Basic Auth)
-k--insecure忽略 SSL 证书验证(不推荐生产环境使用)
--compressed请求服务器返回压缩内容(如 gzip)并自动解压

实际应用场景

1.API 测试

# 测试 REST API curl -X GET https://api.github.com/users/octocat curl -X POST -H "Content-Type: application/json" -d '{"title":"test"}' https://jsonplaceholder.typicode.com/posts

2.下载文件

# 下载并重命名 curl -o ubuntu.iso https://releases.ubuntu.com/22.04/ubuntu-22.04-live-server-amd64.iso # 多文件下载 curl -O https://example.com/file1.txt -O https://example.com/file2.txt

3.网站诊断

# 检查响应时间和状态 curl -w "%{time_total}s\n" -o /dev/null -s https://google.com # 查看完整请求过程 curl -v -L https://example.com

4.使用变量和脚本

# 在脚本中使用 TOKEN="your_token_here" API_URL="https://api.example.com" curl -H "Authorization: Bearer $TOKEN" \ "$API_URL/data"

高级技巧

1.处理 JSON 响应

# 使用 jq 处理 JSON 输出(需要安装 jq) curl -s https://api.github.com/users/octocat | jq '.login, .id' # 格式化 JSON 输出 curl -s https://api.example.com/data | python -m json.tool

2.设置超时

curl --max-time 10 \ # 整个操作最长10秒 --connect-timeout 5 \ # 连接超时5秒 https://example.com

3.并行下载

# 使用 xargs 并行下载多个文件 echo "url1 url2 url3" | xargs -n1 -P3 curl -O



http://www.cnnetsun.cn/news/100737.html

相关文章:

  • 小白也能懂的模板错误解决指南
  • 零基础入门:5分钟学会使用Maven Helper管理依赖
  • 企业级项目中模板错误的实战解决方案
  • 24小时验证:用CMHHP快速构建医疗健康应用原型
  • “十五五”规划下银行人才战略转型,数字化破局银行人才管理四大关键症结
  • R语言下载入门:零基础到实战指南
  • 5分钟快速验证Minecraft插件架构
  • 出STM32智慧系统
  • 3步快速解决Windows安装配置错误
  • AI如何帮你理解traceroute命令?
  • 09 - 使用Django开发Web应用
  • 如何用AI快速解决Python依赖包安装错误
  • GUI Agent:AI如何自动化你的前端开发流程
  • 比传统traceroute快10倍:新一代网络诊断工具
  • 在线魔方解谜站:从零入门到精通的智能魔方学习平台
  • 自动化测试框架搭建:持续验证EmotiVoice输出质量
  • Arthas,阿里巴巴开款的Java诊断神器!
  • 创业者必看!深圳注册代办公司靠谱之选-权威盘点
  • 【异常检测】AdaptCLIP:适配CLIP用于通用视觉异常检测
  • 结合ASR构建完整对话系统:EmotiVoice的角色定位
  • EmotiVoice语音情感强度可视化分析工具介绍
  • 对长上下文能力有不同要求,怎么选择合适的模型?
  • 工程期刊投稿全攻略:高效发表指南
  • vue基于springboot的农业合作社果蔬批发农产品商城信息管理系统的设计与实现
  • vue基于springboot的社区医疗保健健康预警监控系统的设计与实现
  • EmotiVoice能否生成方言情感语音?粤语、川话实测
  • 什么是高带宽内存3(HBM3)?关于HBM3的架构、应用场景和性能表现
  • vue基于springboot的连锁超市销售商城 进销存员工与分析系统的设计与实现
  • AI率一夜飙红后,我用这套方法把论文拉回安全线(降AI率实测版)
  • vue基于springboot的基于建筑物识别的无人驾驶车辆路径规划系统