0

0

如何在Golang中处理JSON解析错误_Golang JSON解析中的错误处理方法

P粉602998670

P粉602998670

发布时间:2026-02-16 09:22:03

|

744人浏览过

|

来源于php中文网

原创

json.unmarshal 解析失败返回 error 而非 panic,需检查 err 并按场景处理;结构体字段须可导出且加 json tag 才能解析;null 值应使用指针类型;大 json 应优先用 json.decoder 流式解析。

如何在golang中处理json解析错误_golang json解析中的错误处理方法

json.Unmarshal 返回错误时,别直接 panic

Go 的 json.Unmarshal 在解析失败时返回 error,不是 panic。常见错误包括字段类型不匹配、JSON 格式非法、结构体字段不可导出等。直接忽略错误或用 panic(err) 会让服务在异常输入下崩溃,尤其在 HTTP API 中极危险。

实操建议:

立即学习go语言免费学习笔记(深入)”;

PHP5学习对象教程
PHP5学习对象教程

PHP5学习对象教程由美国人古曼兹、贝肯、瑞桑斯编著,简张桂翻译,电子工业出版社于2007年12月1日出版的关于PHP5应用程序的技术类图书。该书全面介绍了PHP 5中的新功能、编程方法及设计模式,还分析阐述了PHP 5中新的数据库连接处理、错误处理和XML处理等机制,帮助读者系统了解、熟练掌握和高效应用PHP。

下载
  • 始终检查 err != nil,并根据场景区分处理:对客户端返回 400 Bad Request,对内部日志记录原始 JSON 片段(注意脱敏)
  • 避免用空结构体接收任意 JSON:var v interface{} + json.Unmarshal 成功但后续类型断言失败,错误被延迟到运行时
  • 若需宽松解析(如忽略未知字段),启用 DisallowUnknownFields() 前先确认是否真需要——它会让含额外字段的合法请求失败

结构体字段没加 json tag 导致静默丢失数据

Go 结构体字段默认不会被 json.Unmarshal 解析,除非满足两个条件:字段名首字母大写(可导出),且有对应 json tag 或遵循默认命名规则(如字段 UserName 匹配 JSON 键 "user_name""userName")。没加 tag 又命名不匹配,字段就保持零值,无报错、无提示。

实操建议:

立即学习go语言免费学习笔记(深入)”;

  • 所有参与 JSON 解析的结构体字段,显式加上 json tag,例如:UserID int `json:"user_id"`
  • 使用 omitempty 要谨慎:如果字段为零值(如 0""nil),该字段在序列化时会被跳过;但反向解析时不影响,只是容易误以为“字段没传”
  • 嵌套结构体字段也需 tag,比如 Address AddressInfo `json:"address"`,否则整个 Address 字段为零值

处理 null 值:用指针或 sql.NullXXX 类型

JSON 中的 null 无法直接解到 Go 的非指针基础类型(如 intstringbool),json.Unmarshal 会返回 json: cannot unmarshal null into Go value of type xxx 错误。

实操建议:

立即学习go语言免费学习笔记(深入)”;

  • 对可能为 null 的字段,用指针类型:*string*int64,解完后判空:if req.Name != nil { use(*req.Name) }
  • 若需区分“未提供”和“明确设为 null”,可用自定义类型或三方库(如 guregu/null),但多数 API 场景指针已够用
  • 注意指针解码后仍可能为 nil,不要直接 dereference,否则 panic

流式解析大 JSON 时,json.Decoder 比 Unmarshal 更稳

json.Unmarshal([]byte) 解析大 JSON(如 >1MB)会一次性加载全部内容到内存,易触发 OOM;且错误定位困难——只告诉你“解析失败”,不说明第几行哪一列。

实操建议:

立即学习go语言免费学习笔记(深入)”;

  • 对 HTTP 请求体、文件等流式输入,优先用 json.NewDecoder(r).Decode(&v),它边读边解析,内存占用低
  • Decoder 支持设置 DisallowedUnknownFields() 和自定义 Number 类型(避免 float64 精度丢失整数 ID)
  • 错误位置可通过包装 io.Reader 实现行号追踪,例如用 bufio.Scanner 配合 bytes.NewReader 做调试,但生产环境通常只需记录原始 payload hash + 错误信息
实际项目里最常被忽略的是字段可导出性与 tag 的组合问题——看着代码没报错,但数据就是不进来,查半天才发现 struct 字段小写了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

207

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

238

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

347

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

212

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

403

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

344

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

197

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

888

2025.06.17

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 9.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号