新闻中心
Golang如何使用net/http实现REST接口_Golang net/http REST接口实践详解
答案:使用Go标准库net/http可高效构建REST接口,通过HTTP方法对应资源操作,结合路由注册、JSON处理、状态码设置及中间件提升可维护性。示例展示了用户服务的增删改查,支持GET、POST等方法,返回标准JSON格式,并推荐添加日志、统一错误处理和响应结构,适用于轻量级API或微服务场景。

理解REST与HTTP方法对应关系
REST(Representational State Transfer)是一种设计风格,强调资源的操作通过标准 HTTP 方法完成。常见操作与 HTTP 方法对应如下:
- GET:获取资源
- POST:创建资源
- PUT:更新资源(全量)
- PATCH:部分更新资源
- DELETE:删除资源
- GET /users → 获取用户列表
- POST /users → 创建新用户
- GET /users/1 → 获取 ID 为 1 的用户
- PUT /users/1 → 更新该用户信息
- DELETE /users/1 → 删除该用户
使用net/http注册路由并处理请求
net/http 提供了 DefaultServeMux 作为默认的多路复用器,可通过 http.HandleFunc 注册路径和处理器函数。
示例:定义一个简单的用户服务package main
import (
"encoding/json"
"log"
"net/http"
)
type User struct {
ID int `json:"id"`
Name string `json:"name"`
Email string `json:"email"`
}
var users = []User{
{ID: 1, Name: "Alice", Email: "alice@example.com"},
}
func getUsers(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(users)
}
func createUser(w http.ResponseWriter, r *http.Request) {
if r.Method != "POST" {
http.Error(w, "只支持 POST 请求", http.StatusMethodNotAllowed)
return
}
var user User
if err := json.NewDecoder(r.Body).Decode(&user); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
user.ID = len(users) + 1
users = append(users, user)
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusCreated)
json.NewEncoder(w).Encode(user)
}
func getUserByID(w http.ResponseWriter, r *http.Request) {
id := r.URL.Path[len("/users/"):]
for _, u := range users {
if fmt.Sprint(u.ID) == id {
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(u)
return
}
}
http.Error(w, "用户不存在", http.StatusNotFound)
}
func main() {
http.HandleFunc("/users", func(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" {
getUsers(w, r)
} else if r.Method == "POST" {
createUser(w, r)
} else {
http.Error(w, "不支持的方法", http.StatusMethodNotAllowed)
}
})
http.HandleFunc("/users/", getUserByID)
log.Println("服务器启动在 :8080")
log.Fatal(http.ListenAndServe(":8080", nil))
}
提升可维护性:自定义路由与中间件
随着接口增多,使用 DefaultServeMux 可能不够灵活。可以手动创建 ServeMux 或封装更清晰的结构。
PictoGraphic
AI驱动的矢量插图库和插图生成平台
133
查看详情
建议做法:
- 按资源分组路由
- 统一错误处理格式
- 添加日志、CORS、认证等中间件
func loggingMiddleware(next http.HandlerFunc) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
log.Printf("%s %s %s", r.RemoteAddr, r.Method, r.URL)
next(w, r)
}
}
使用中间件包装处理器:
http.HandleFunc("/users", loggingMiddleware(getUsers))
处理JSON与状态码的最佳实践
正确设置响应头、状态码和 JSON 输出是构建专业 API 的关键。
- 始终设置 Content-Type: application/json
- 创建资源返回 StatusCreated (201)
- 成功但无内容返回 StatusNoContent (204)
- 参数错误使用 StatusBadRequest (400)
- 资源未找到返回 StatusNotFound (404)
- 方法不支持返回 StatusMethodNotAllowed (405)
type Response struct {
Success bool `json:"success"`
Data interface{} `json:"data,omitempty"`
Message string `json:"message,omitempty"`
}
基本上就这些。用 net/http 写 REST 接口不复杂但容易忽略细节,比如方法判断、错误编码、头部设置。只要结构清晰、遵循规范,完全可以不用 Gin 或 Echo 就上线小型服务。以上就是Golang如何使用net/http实现REST接口_Golang net/http REST接口实践详解的详细内容,更多请关注其它相关文章!
# 遂宁营销推广免费咨询平台
# 该用户
# 资源管理
# 是一种
# 如何在
# 适用于
# 相关文章
# 鄂州网站优化推广公司
# 周口网站建设招聘信息
# 不支持
# 网络运营与推广营销方案
# 康佳T25SEO78
# seo网站找27火星
# 怎样快速的优化网站
# 深圳抖音推广营销策划案
# 茶陵营销推广网站推荐
# 辽宁关键词优化公司排名
# usb
# 前端
# json
# go
# golang
# 处理器
# go语言
# 编码
# app
# js
# 后端
# ai
# 路由
# 状态码
# json处理
# 加载
# 如何使用
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
如何在CSS中使用visited与link控制链接颜色_visited link伪类配合
Mac怎么查看崩溃日志_Mac控制台错误报告分析
CSS Grid如何控制元素对齐_align-items与justify-items组合使用
J*aScript DOM操作:高效清空列表元素的策略与实践
创客贴用户入口官网登录 创客贴网页版电脑版系统
poki网页游戏推荐_poki免费游戏平台入口
如何使用Node.js csv 包按条件移除含空字段的CSV记录
mysql如何设置表访问权限_mysql表访问权限配置
UC浏览器网页版登录入口官网 电脑版网址入口
jQuery Mask 插件中实现电话号码固定前导零的教程
“在文档元素之后找到了标记”是什么错误? 检查并修复XML中多个根元素的3个方法
Lar*el用户头像管理:实现图片缩放、存储与旧文件安全删除的最佳实践
b站怎么删除评论_b站评论管理与删除操作
TikTok网页版直接登录 TikTok网页端官方平台入口
C++如何检测键盘输入_C++ _kbhit与_getch函数非阻塞输入
抖音小游戏合成大西瓜免费秒玩入口链接 抖音小游戏热门合集秒玩网站
Golang如何处理RPC请求负载均衡_Golang RPC请求负载均衡策略与实践
《刺客信条4:黑旗》重制版新细节曝光:无缝加载 地图更细致!
优化Log4j2控制台输出性能:解决异步日志瓶颈
微信网页版官方入口教程 微信网页版网页版快速登录步骤
C++如何进行游戏物理模拟_使用Box2D库为C++游戏添加2D物理效果
Python中高效访问嵌套字典与列表中的键值对
qq游戏网页版直接玩_qq游戏免下载快速入口
LINQ to XML为何解析失败? 深入理解C# XDocument的异常处理
特斯拉自动驾驶房车计划曝光 原型车将于2027年亮相
Pygame教程:解决用户输入与游戏状态更新不同步问题
Safari浏览器输入栏卡顿如何解决 Safari搜索建议与缓存清理
CSS自定义字体样式被系统字体替换怎么办_font-face方式指定font-display控制渲染策略
C++如何比较两个字符串_C++ string compare函数与操作符对比
QQ网页版官方账号入口 QQ网页版网页版登录指南
魅族17怎样用浏览器译外语网页_iPhone魅族17浏览器译外语网页【即时翻译】
sublime如何配置Go语言开发环境_sublime搭建Golang编译运行系统
J*a里如何使用N*igableMap进行导航操作_可导航Map操作技巧解析
汽水音乐在线版入口_汽水音乐网页播放手册
厨房不锈钢水槽发黑生锈怎么处理_水槽用可乐+锡纸2分钟抛亮如新
qq浏览器打开空白页怎么办 qq浏览器启动后显示白屏的解决教程
一加手机电池耗电快怎么办_一加手机电池耗电快的解决方法
在J*a中如何开发简易电子商务商品管理系统_商品管理系统项目实战解析
ACG动漫手机版官网入口 手机ACG动漫APP在线观看正版
邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧
12306选座怎么选到临时改签座_12306改签选座策略与步骤
React/Next.js中实现列表项的动态选择与移动
Mac怎么锁定备忘录_Mac备忘录加密设置教程
Golang如何实现Web文件静态资源服务器_Golang静态资源服务器开发与实践
Python大型XML文件高效流式解析教程
汽水音乐车机版8.9下载 汽水音乐车机版8.9版本安装入口
Bilibili动漫最新防封地址发布-Bilibili动漫2025年最稳正版入口推荐
怎样使用“本地安全策略”提升Windows安全性_Secpol.msc配置指南【高手】
响应式容器内容自动缩放与宽高比维持教程
微信客户端如何收红包_微信客户端接收红包使用教程


2025-11-23
浏览次数:次
返回列表
return
}
var user User
if err := json.NewDecoder(r.Body).Decode(&user); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
user.ID = len(users) + 1
users = append(users, user)
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusCreated)
json.NewEncoder(w).Encode(user)
}
func getUserByID(w http.ResponseWriter, r *http.Request) {
id := r.URL.Path[len("/users/"):]
for _, u := range users {
if fmt.Sprint(u.ID) == id {
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(u)
return
}
}
http.Error(w, "用户不存在", http.StatusNotFound)
}
func main() {
http.HandleFunc("/users", func(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" {
getUsers(w, r)
} else if r.Method == "POST" {
createUser(w, r)
} else {
http.Error(w, "不支持的方法", http.StatusMethodNotAllowed)
}
})
http.HandleFunc("/users/", getUserByID)
log.Println("服务器启动在 :8080")
log.Fatal(http.ListenAndServe(":8080", nil))
}