当前位置:首页 > 文章列表 > 文章 > 软件教程 > curl + jq 接口调试实战:把混乱 JSON 快速看明白

curl + jq 接口调试实战:把混乱 JSON 快速看明白

来源:17golang原创 2026-06-13 08:06:23 0浏览 收藏

调接口时,很多人第一反应是打开浏览器或接口工具。它们当然好用,但在服务器、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'

curl 请求接口后用 jq 从返回 JSON 中筛选字段并查看结果

这张图对应完整流程:先请求接口,再拿到返回 JSON,然后筛出字段,最后只看调试需要的结果。它的好处是把“数据很全”和“我只关心少数字段”分开处理。

常用 jq 写法

# 读取顶层字段
jq '.code'

# 读取数组长度
jq '.data | length'

# 过滤指定状态
jq '.data[] | select(.status == "active")'

# 给字段改名,方便贴到排查记录里
jq '.data[] | {user_id: .id, username: .name, state: .status}'

建议先从简单路径开始写,不要一上来就写很长的表达式。每次只加一层筛选,能减少排查时的误判。

三、接口失败时按四步排查

接口失败时,不建议只盯着“报错了”三个字。比较稳定的顺序是:看状态码、读响应体、查请求头、修复后重试。

接口失败时用 curl 按状态码响应体请求头和重试步骤排查问题

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 筛关键字段;遇到失败时按“状态码、响应体、请求头、修复重试”的顺序排查。熟练以后,它会成为接口调试里非常顺手的一把小工具。

版本声明
本文转载于:17golang原创 如有侵犯,请联系study_golang@163.com删除
Redis 缓存雪崩治理实战:TTL 抖动、预热和降级保护怎么做Redis 缓存雪崩治理实战:TTL 抖动、预热和降级保护怎么做
上一篇
Redis 缓存雪崩治理实战:TTL 抖动、预热和降级保护怎么做
Python argparse 命令行工具实战:子命令、参数校验和配置合并
下一篇
Python argparse 命令行工具实战:子命令、参数校验和配置合并
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    8093次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    8526次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    8347次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    10253次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    9134次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码