0

0

如何使用Golang encoding/json解析JSON_Golang encoding/json解析与序列化示例

P粉602998670

P粉602998670

发布时间:2026-01-01 16:50:02

|

406人浏览过

|

来源于php中文网

原创

Go 的 encoding/json 包要求结构体字段导出(首字母大写)才能解析,非导出字段被静默跳过;需用 json:"key" 标签显式映射,支持蛇形转驼峰但有限制;数组/对象须严格对应切片/struct;空值处理推荐 *T 或 json.RawMessage;混合类型应先用 map[string]json.RawMessage 延迟解析。

如何使用golang encoding/json解析json_golang encoding/json解析与序列化示例

Go 的 encoding/json 包能直接将 JSON 映射为结构体,但前提是字段名匹配且导出(首字母大写),否则解析会静默失败或字段为空。

结构体字段必须导出才能被 json.Unmarshal 处理

Go 的反射机制无法访问非导出字段(小写开头),json.Unmarshal 会跳过它们,不报错也不赋值。

  • 确保结构体字段首字母大写,例如 UserName 而非 userName
  • json 标签显式指定 JSON 键名,大小写无关: UserName string `json:"user_name"`
  • 如果 JSON 键是 "user_id",而结构体字段是 UserID int,不加标签也能解析成功(Go 默认做蛇形转驼峰),但这是有限制的:仅支持简单下划线分隔,不支持多下划线或数字混排(如 "user_id_v2" 不会自动转成 UserIDV2

处理嵌套对象与切片时,类型必须严格对应

JSON 数组必须映射为 Go 切片([]T),JSON 对象必须映射为 struct 或 map[string]interface{};类型错配会导致 json.Unmarshal 返回 invalid charactercannot unmarshal object into Go value of type []xxx 类错误。

  • 嵌套结构体需定义对应子 struct,不能用 interface{} 除非你后续手动断言
  • JSON 中可能缺失的字段,建议用指针类型(如 *string)或加 omitempty 标签避免零值干扰
  • 若不确定某字段是对象还是字符串(如某些 API 返回 "data": {}"data": "null"),优先用 json.RawMessage 延迟解析

反序列化空值、null 和缺失字段的差异

JSON 中的 null、字段不存在、空字符串,在 Go 结构体中表现不同,直接影响业务逻辑判断。

Lifetoon
Lifetoon

免费的AI漫画创作平台

下载

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

  • string 字段遇到 JSON null → 解析失败(invalid character 'n' looking for beginning of value),除非字段类型是 *string
  • *string 遇到 null → 指针为 nil;遇到缺失字段 → 也是 nil;二者无法区分,需靠业务约定或额外字段标识
  • sql.NullString 可区分 Valid == false(null 或缺失)和 Valid == true && String == ""(空字符串),适合对接数据库场景
type User struct {
    ID       int64  `json:"id"`
    Name     string `json:"name"`
    Avatar   *string `json:"avatar,omitempty"`
    Metadata json.RawMessage `json:"metadata"`
}

data := []byte(`{"id": 123, "name": "alice", "avatar": null}`)
var u User
err := json.Unmarshal(data, &u)
// u.Avatar == nil,u.Metadata == json.RawMessage("null") —— 注意:RawMessage 不会解析,保留原始字节

真正麻烦的是混合类型字段(比如某个字段有时是对象、有时是字符串),这时候别硬套 struct,先用 map[string]json.RawMessage 提取再按需解析,否则容易 panic 或丢数据。

相关专题

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

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

174

2024.02.23

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

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

225

2024.02.23

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

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

335

2024.02.23

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

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

206

2024.03.05

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

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

388

2024.05.21

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

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

193

2025.06.09

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

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

188

2025.06.10

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

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

191

2025.06.17

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

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

精品课程

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

共101课时 | 8.1万人学习

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

共39课时 | 3.1万人学习

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

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