定义结构体并使用json标签处理JSON序列化与反序列化,通过json.Marshal发送POST请求,用json.NewDecoder解析响应,结合net/http包处理状态码与错误,支持嵌套结构与动态字段。

在Golang中处理JSON API请求与响应是构建现代Web服务和客户端调用的常见需求。Go标准库提供了encoding/json、net/http等包,配合结构体标签(struct tags)可以高效地完成序列化与反序列化。以下是常用的处理方法汇总。
定义结构体以映射JSON数据
处理JSON的第一步是定义Go结构体,使用json:标签来控制字段的序列化行为。
例如,一个用户信息的响应结构:
type User struct { ID int `json:"id"` Name string `json:"name"` Email string `json:"email,omitempty"`}
omitempty表示当Email为空时,该字段不会出现在输出JSON中。这是控制可选字段的重要方式。
立即学习“go语言免费学习笔记(深入)”;
发送JSON请求(POST/PUT)
向API发送JSON数据通常用于创建或更新资源。需要将结构体编码为JSON,并设置正确的Content-Type头。
示例:发送POST请求创建用户
user := User{Name: "Alice", Email: "alice@example.com"}jsonData, _ := json.Marshal(user)resp, err := http.Post("https://api.example.com/users", "application/json", bytes.NewBuffer(jsonData))if err != nil { log.Fatal(err)}defer resp.Body.Close()
关键点:
使用json.Marshal将结构体转为JSON字节流 请求Body需包装为bytes.NewBuffer Header设置Content-Type: application/json(某些API强制要求)
解析JSON响应
从API接收JSON后,通常需要反序列化到结构体中。
示例:读取GET响应并解析
resp, err := http.Get("https://api.example.com/users/1")if err != nil { log.Fatal(err)}defer resp.Body.Close()var user Userif err := json.NewDecoder(resp.Body).Decode(&user); err != nil { log.Fatal(err)}fmt.Printf("User: %+vn", user)
这里使用json.NewDecoder直接从io.Reader(如resp.Body)解码,适合处理HTTP响应流。
处理嵌套JSON与动态字段
实际API中常有嵌套结构或不确定字段。可通过嵌套结构体或使用map[string]interface{}处理。
例如处理包含元数据的响应:
type Response struct { Data User `json:"data"` Meta map[string]interface{} `json:"meta"`}
若字段类型不固定,可用interface{}接收,再通过类型断言提取值:
if version, ok := response.Meta["version"].(string); ok { fmt.Println("Version:", version)}
错误处理与状态码判断
不要忽略HTTP状态码。即使请求返回,也可能携带错误信息。
建议做法:
if resp.StatusCode != http.StatusOK { var errorResp map[string]string json.NewDecoder(resp.Body).Decode(&errorResp) log.Fatal("API error:", errorResp["message"])}
很多API在非200状态时仍返回JSON格式错误,应尝试解析并提示用户。
基本上就这些。掌握结构体标签、json.Marshal/Unmarshal、http.Client的基本用法,就能应对大多数JSON API场景。关键是设计好结构体,合理处理空值和错误响应。
以上就是如何在Golang中处理JSON API请求与响应_Golang JSON API请求响应处理方法汇总的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1419801.html
微信扫一扫
支付宝扫一扫