curl + jq 接口调试实战:把混乱 JSON 快速看明白
调接口时,很多人第一反应是打开浏览器或接口工具。它们当然好用,但在服务器、CI 脚本、远程排查场景里,命令行更直接:一条 curl 发请求,一条 jq 把 JSON 筛成你真正想看的字段。
本文用一个用户列表接口做例子,演示如何从“满屏 JSON 看不清”走到“关键字段一眼看到”。同时也会给出接口失败时的排查顺序:先看状态码,再读响应体,再查请求头和超时。
摘要
curl 负责发起 HTTP 请求,jq 负责整理 JSON。组合使用时,可以快速完成接口连通性检查、字段提取、错误定位和脚本化验证。核心思路是:先拿到原始响应,再用 jq 逐层筛选,最后把排查步骤固定成可复用命令。
适合人群
适合后端、前端、测试、运维同学。只要你经常排查接口返回、线上配置、第三方回调、JSON 日志,就能把这套方法放进日常工作流里。
目录
- 先确认接口能不能通
- 用 jq 把 JSON 筛成可读结果
- 接口失败时按四步排查
- 把常用命令整理成脚本片段
- 常见问题和总结
一、先确认接口能不能通
第一步不要急着写复杂筛选,先确认接口是否能正常返回。下面这个例子用 -s 关闭进度条,用 -i 带上响应头,方便同时看状态码和响应体。
curl -s -i "https://api.example.com/users?page=1"
如果接口需要认证,把请求头带上即可。实际排查时不要把真实 token 写进共享文档或提交到仓库,可以从环境变量读取。
curl -s \
-H "Authorization: Bearer ${API_TOKEN}" \
-H "Accept: application/json" \
"https://api.example.com/users?page=1"
这一步只回答一个问题:请求有没有到达目标服务,服务有没有给出 JSON。确认通了以后,再开始筛字段。
二、用 jq 把 JSON 筛成可读结果
假设接口返回结构大致如下:
{
"code": 0,
"data": [
{"id": 101, "name": "Alice", "status": "active", "role": "admin"},
{"id": 102, "name": "Bob", "status": "disabled", "role": "user"}
],
"meta": {"page": 1, "total": 2}
}
直接看完整 JSON 还行,但线上接口字段一多就会很累。可以先用 jq 美化输出:
curl -s "https://api.example.com/users?page=1" | jq '.'
再提取列表里的几个关键字段:
curl -s "https://api.example.com/users?page=1" \
| jq '.data[] | {id, name, status}'
如果想把结果变成更适合终端查看的一行一条,可以用 -r 输出纯文本:
curl -s "https://api.example.com/users?page=1" \ | jq -r '.data[] | [.id, .name, .status] | @tsv'

这张图对应完整流程:先请求接口,再拿到返回 JSON,然后筛出字段,最后只看调试需要的结果。它的好处是把“数据很全”和“我只关心少数字段”分开处理。
常用 jq 写法
# 读取顶层字段
jq '.code'
# 读取数组长度
jq '.data | length'
# 过滤指定状态
jq '.data[] | select(.status == "active")'
# 给字段改名,方便贴到排查记录里
jq '.data[] | {user_id: .id, username: .name, state: .status}'
建议先从简单路径开始写,不要一上来就写很长的表达式。每次只加一层筛选,能减少排查时的误判。
三、接口失败时按四步排查
接口失败时,不建议只盯着“报错了”三个字。比较稳定的顺序是:看状态码、读响应体、查请求头、修复后重试。

1. 看状态码
用 -w 单独输出 HTTP 状态码,适合脚本和排查记录。
curl -s -o /tmp/users-body.json \
-w "status=%{http_code} time=%{time_total}\n" \
"https://api.example.com/users?page=1"
2xx 说明请求基本成功;4xx 多半是参数、权限、路径问题;5xx 更偏服务端异常或依赖异常。状态码不是最终答案,但能把方向先分出来。
2. 读响应体
状态码只告诉你大类,响应体经常会告诉你具体原因。
jq '{code, message, detail}' /tmp/users-body.json
如果响应体不是 JSON,jq 会报解析错误。这时反而说明要先确认服务是否返回了 HTML 错误页、网关提示页,或者压根不是预期接口。
3. 查请求头
很多接口问题不是业务参数错,而是请求头没带全,比如认证、内容类型、灰度标记、租户标识。
curl -s -i \
-H "Authorization: Bearer ${API_TOKEN}" \
-H "Content-Type: application/json" \
"https://api.example.com/users?page=1"
如果接口要求 JSON 请求体,建议显式带上 Content-Type,不要依赖默认行为。
4. 修复后重试
重试前要先修复原因,例如补参数、换 token、改路径、延长超时。不要在原因未知时疯狂重试,否则可能把对方服务或自己的网关压得更重。
curl -s --connect-timeout 3 --max-time 10 \
-H "Authorization: Bearer ${API_TOKEN}" \
"https://api.example.com/users?page=1" \
| jq '.data[] | {id, name, status}'
四、把常用命令整理成脚本片段
当同一个接口要反复排查时,可以把地址、请求头、输出格式整理成一个小片段。下面示例把接口响应保存到文件,再用 jq 输出关键信息。
API_BASE="https://api.example.com"
API_PATH="/users?page=1"
BODY_FILE="/tmp/users-body.json"
curl -s -o "${BODY_FILE}" \
-w "status=%{http_code} time=%{time_total}\n" \
-H "Authorization: Bearer ${API_TOKEN}" \
"${API_BASE}${API_PATH}"
jq -r '.data[] | [.id, .name, .status] | @tsv' "${BODY_FILE}"
这个片段不追求复杂,只解决一个问题:同样的接口,同样的请求头,同样的输出方式,下一次排查不用从零开始敲。
常见问题
1. jq 报 Cannot index array 怎么办?
说明你把对象路径和数组路径写混了。先运行 jq '.' 看清结构,再决定是用 .data.name 还是 .data[] | .name。
2. 为什么 curl 返回的是 HTML?
常见原因是路径写错、网关拦截、登录态过期、服务返回错误页。先加 -i 看响应头,再看状态码和 Content-Type。
3. token 不想显示在历史记录里怎么办?
可以把 token 放到环境变量里,或者从本地安全配置读取。不要把真实 token 写到文章、日志、脚本仓库或群聊截图里。
总结
curl + jq 的组合适合快速、稳定、可复用地调试 JSON 接口。先用 curl 拿到响应,再用 jq 筛关键字段;遇到失败时按“状态码、响应体、请求头、修复重试”的顺序排查。熟练以后,它会成为接口调试里非常顺手的一把小工具。
Redis 缓存雪崩治理实战:TTL 抖动、预热和降级保护怎么做
- 上一篇
- Redis 缓存雪崩治理实战:TTL 抖动、预热和降级保护怎么做
- 下一篇
- Python argparse 命令行工具实战:子命令、参数校验和配置合并
-
- 文章 · 软件教程 | 10分钟前 | 软件教程 · OBS Studio · 录屏 · 视频录制 · 软件教程 录屏设置 OBS Studio 窗口采集 音频混音器 录制路径
- OBS Studio 录屏设置实战:窗口采集、音频检查和录制路径这样配
- 105浏览 收藏
-
- 文章 · 软件教程 | 1星期前 |
- 小红书双击点赞怎么用?实用互动技巧
- 397浏览 收藏
-
- 文章 · 软件教程 | 1星期前 |
- Word插入Excel表格制作教程
- 460浏览 收藏
-
- 文章 · 软件教程 | 1星期前 |
- 按住Ctrl组合图形无效解决方法
- 296浏览 收藏
-
- 文章 · 软件教程 | 1星期前 |
- 开启Windows 11硬件加速视频解码方法
- 351浏览 收藏
-
- 文章 · 软件教程 | 1星期前 |
- 美图秀秀贴纸添加技巧分享
- 128浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 8093次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 8526次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 8347次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 10253次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 9134次使用
-
- golang生成JSON以及解析JSON
- 2023-01-17 329浏览
-
- Go如何实现json字符串与各类struct相互转换
- 2023-01-07 377浏览
-
- Go中使用gjson来操作JSON数据的实现
- 2023-01-07 141浏览
-
- Go 语言 json解析框架与 gjson 详解
- 2023-01-08 203浏览
-
- Go语言中的数据格式(json、xml 、msgpack、protobuf)使用总结
- 2022-12-28 264浏览

