答案是使用Go标准库可轻松实现支持GET和POST的JSON API。通过net/http注册路由,定义Data结构体,GET返回预设数据,POST解析请求体并回显,设置正确Content-Type头,最终用curl测试正常收发JSON。

用Golang编写一个能处理GET和POST请求的简单JSON API并不复杂。Go的标准库提供了足够的工具,无需引入外部框架即可实现。下面是一个完整、可运行的示例,展示如何创建一个接收JSON数据、返回JSON响应的基础API。
使用net/http包启动一个HTTP服务器,并注册处理函数。
以下代码启动服务器并监听:8080端口:
立即学习“go语言免费学习笔记(深入)”;
package main
import (
"encoding/json"
"log"
"net/http"
)
func main() {
http.HandleFunc("/api/data", handleData)
log.Println("Server starting on :8080")
log.Fatal(http.ListenAndServe(":8080", nil))
}
当客户端发送GET请求到/api/data时,返回预设的JSON数据。
type Data struct {
ID int `json:"id"`
Name string `json:"name"`
}
func handleData(w http.ResponseWriter, r *http.Request) {
switch r.Method {
case "GET":
data := Data{ID: 1, Name: "example"}
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(data)
case "POST":
// 处理POST见下文
default:
http.Error(w, "Method not allowed", http.StatusMethodNotAllowed)
}
}
客户端发送JSON数据到/api/data,服务端解析并返回确认信息。
更新handleData中的POST分支:
case "POST":
var data Data
if err := json.NewDecoder(r.Body).Decode(&data); err != nil {
http.Error(w, "Invalid JSON", http.StatusBadRequest)
return
}
// 简单响应,回显收到的数据
response := map[string]string{
"status": "received",
"id": fmt.Sprintf("%d", data.ID),
"name": data.Name,
}
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusCreated)
json.NewEncoder(w).Encode(response)
别忘了导入"fmt"包。
启动服务:
go run main.go
测试GET请求:
curl -X GET http://localhost:8080/api/data
输出:
{"id":1,"name":"example"}测试POST请求:
curl -X POST http://localhost:8080/api/data \
-H "Content-Type: application/json" \
-d '{"id": 2, "name": "test"}'输出:
{"status":"received","id":"2","name":"test"}基本上就这些。这个小例子展示了Go如何轻松处理JSON API的核心需求:路由、解析请求、生成响应。你可以在此基础上扩展验证、数据库交互或中间件功能。
以上就是如何用Golang编写一个处理GET和POST请求的简单JSON API的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号