答案:Go语言通过net/http库可快速构建REST API,结合gorilla/mux实现路由管理,支持JSON数据处理与标准HTTP方法操作。

在Golang中实现REST API服务并不复杂,Go语言标准库提供了足够的支持来快速搭建一个高效、可靠的HTTP服务。结合简洁的语法和强大的并发模型,Go非常适合构建RESTful后端服务。
使用net/http标准库创建基础HTTP服务
Go内置的net/http包可以轻松启动一个HTTP服务器。你只需要定义路由和处理函数即可。
示例代码:
package main
import (
"encoding/json"
"net/http"
)
func helloHandler(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(map[string]string{"message": "Hello, World!"})
}
func main() {
http.HandleFunc("/hello", helloHandler)
http.ListenAndServe(":8080", nil)
}
这段代码注册了一个/hello路由,并返回JSON格式的响应。通过http.HandleFunc绑定URL路径与处理函数。
立即学习“go语言免费学习笔记(深入)”;
设计RESTful路由与请求处理
REST API通常围绕资源设计,比如用户(User)、订单(Order)等。每个资源对应一组标准操作:获取列表、创建、读取、更新、删除。
你可以通过检查r.Method来区分不同的HTTP方法:
func userHandler(w http.ResponseWriter, r *http.Request) {
switch r.Method {
case "GET":
// 获取用户列表或单个用户
getUsers(w, r)
case "POST":
// 创建用户
createUser(w, r)
default:
http.Error(w, "Method not allowed", http.StatusMethodNotAllowed)
}
}
对于路径参数(如/users/123),标准库本身不支持通配符路由,但可以通过第三方库如gorilla/mux或chi实现。
使用Gorilla Mux增强路由功能
gorilla/mux是一个流行的路由器,支持变量路径、正则匹配和中间件。
安装:
go get github.com/gorilla/mux
示例:
router := mux.NewRouter()
router.HandleFunc("/users", getUsers).Methods("GET")
router.HandleFunc("/users/{id}", getUser).Methods("GET")
router.HandleFunc("/users", createUser).Methods("POST")
router.HandleFunc("/users/{id}", updateUser).Methods("PUT")
router.HandleFunc("/users/{id}", deleteUser).Methods("DELETE")
http.ListenAndServe(":8080", router)
在处理函数中,可通过mux.Vars(r)["id"]获取路径参数。
处理请求数据与返回JSON响应
从客户端接收JSON数据时,通常需要解析请求体:
type User struct {
ID int `json:"id"`
Name string `json:"name"`
}
func createUser(w http.ResponseWriter, r *http.Request) {
var user User
if err := json.NewDecoder(r.Body).Decode(&user); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
// 保存逻辑(例如存入数据库)
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusCreated)
json.NewEncoder(w).Encode(user)
}
记得设置正确的状态码,如201 Created用于资源创建成功。
基本上就这些。用Go写REST API可以很轻量,也可以结合框架扩展。关键是理解HTTP语义和资源设计。随着业务增长,再考虑加入中间件、验证、日志、错误处理等机制。不复杂但容易忽略细节。










