当前位置: 首页 > news >正文

Go语言实战案例:简易JSON数据返回

在现代 Web 应用中,JSON 已成为前后端通信的主流数据格式。Go 语言标准库内置对 JSON 的良好支持,只需少量代码就能返回结构化的 JSON 响应。

本篇案例将手把手带你完成一个「返回 JSON 数据的 HTTP 接口」,帮助你理解如何用 Go 语言实现后端服务最基础的功能。


一、目标说明

构建一个 HTTP 服务:

  • • 请求地址:/hello
  • • 请求方式:GET
  • • 返回内容:
    {"message": "Hello, Go!","status": 200
    }

二、核心知识点

  • • net/http:Go 标准 HTTP 库
  • • encoding/json:JSON 编解码包
  • • http.ResponseWriter:响应写入器
  • • http.HandleFunc:注册处理函数

三、完整代码示例

package mainimport ("encoding/json""net/http"
)type Response struct {Message string `json:"message"`Status  int    `json:"status"`
}func helloHandler(w http.ResponseWriter, r *http.Request) {// 设置返回头信息w.Header().Set("Content-Type", "application/json")w.WriteHeader(http.StatusOK)// 创建响应结构体resp := Response{Message: "Hello, Go!",Status:  200,}// 编码为 JSON 并写入响应json.NewEncoder(w).Encode(resp)
}func main() {http.HandleFunc("/hello", helloHandler)http.ListenAndServe(":8080", nil)
}

四、运行与测试

1. 运行服务
go run main.go

访问浏览器或使用 curl

curl http://localhost:8080/hello
2. 响应结果
{"message": "Hello, Go!","status": 200
}

五、快速问答(FAQ)

✅ 为什么要设置 Content-Type: application/json

告诉浏览器或客户端,我们返回的是 JSON 格式数据。

✅ json.NewEncoder(w).Encode(...) 做了什么?

它将结构体编码为 JSON 并直接写入到 ResponseWriter 输出流。

✅ 如果编码失败会发生什么?

Encode() 会返回 error,可以用 if err != nil 判断并手动写入 500 错误。


六、延伸练习

  1. 1. 返回一个包含用户列表的 JSON 数组;
  2. 2. 增加 POST 方法处理 JSON 请求体;
  3. 3. 返回当前时间戳;
  4. 4. 返回分页数据结构。

七、总结

本案例实现了一个 Go 最小可用的 JSON 接口:

✅ 使用标准库,无需第三方框架
✅ 面向新手,极易上手
✅ 为构建 RESTful API 打下基础


http://www.xdnf.cn/news/1261189.html

相关文章:

  • 微软Azure AI Foundry正式上线GPT-5系列模型
  • 5 种简单方法将 Safari 书签转移到新 iPhone
  • 代码随想录刷题Day26
  • Pytest项目_day10(接口的参数传递)
  • WORD接受修订,并修改修订后文字的颜色
  • Autosar AP功能组状态和模型进程是否预定义后不改变了?
  • Electron——窗口
  • 嵌入式硬件接口总结
  • 2025华数杯数学建模A题【 多孔膜光反射性能的优化与控制】原创论文分享
  • 6、图片上方添加波浪效果
  • Java开发者的AI革命:飞算JavaAI全流程实战与对比评测
  • Java基础知识总结
  • Harbor 企业级实战:单机快速上手 × 高可用架构搭建 × HTTPS安全加固
  • 宝龙地产债务化解解决方案二:基于资产代币化与轻资产转型的战略重构
  • 微信小程序性能优化
  • 宝龙地产债务化解解决方案一:基于资产代币化与轻资产转型的战略重构
  • 【高等数学】第八章 向量代数与空间解析几何——第三节 平面及其方程
  • C语言中的数据结构--树
  • apache cgi测试
  • 安全合规1--实验:ARP欺骗、mac洪水攻击、ICMP攻击、TCP SYN Flood攻击
  • 操作系统-实验-进程
  • 以下是使用这款ePub编辑器将指定章节转换为TXT文本文档的操作方法
  • (已解决)IDEA突然无法使用Git功能
  • 手机拍照识别中模糊场景准确率↑37%:陌讯动态适配算法实战解析
  • hyper-v虚拟机启动失败:Virtual Pci Express Port无法打开电源,因为发生错误,找不到即插即用设备
  • SQL Server 2019搭建AlwaysOn高可用集群
  • Money Sums
  • 【优选算法】BFS解决拓扑排序
  • UE4/UE5 Android 超大(视频)文件打包/防拷贝方案
  • Linux 内存管理之page folios