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

Web开发实战:Gin + GORM 构建企业级 API 项目

🚀 Web开发实战:Gin + GORM 构建企业级 API 项目

Gin 是当下最受欢迎的 Golang Web 框架之一,GORM 是使用最广泛的 ORM 框架。两者组合可快速开发高性能、结构清晰、维护方便的 API 项目。本文将带你从 0 到 1 构建一个完整的 Web 后端服务,适用于管理后台、微服务、BFF 等场景。


🧱 一、项目目标:构建一个用户管理 API

实现接口功能包括:

  • 用户注册
  • 用户登录(JWT)
  • 用户列表查询(分页)
  • 用户详情、更新与删除
  • 权限接口预留

📦 二、技术栈

类别技术说明
Web框架Gin路由、请求处理
ORMGORM数据库访问
数据库MySQL/PostgreSQL关系型数据库
配置管理Viper支持配置文件/env参数等
日志记录Zap高性能结构化日志
鉴权JWTToken登录鉴权
热重载工具Air本地开发体验提升

📁 三、项目结构设计

go-gin-api/
├── config/          # 配置相关
├── controller/      # 控制器层
├── middleware/      # 中间件
├── model/           # 数据模型
├── router/          # 路由注册
├── service/         # 业务逻辑处理
├── utils/           # 通用工具类
├── main.go          # 程序入口
└── go.mod

✅ 强烈推荐分层架构(Controller → Service → Model),便于单测和扩展。


🔧 四、环境初始化

1. 初始化 Go 模块

go mod init go-gin-api

2. 安装依赖

go get -u github.com/gin-gonic/gin
go get -u gorm.io/gorm
go get -u gorm.io/driver/mysql
go get -u github.com/spf13/viper
go get -u go.uber.org/zap
go get -u github.com/golang-jwt/jwt/v5

🗃️ 五、数据库配置 & GORM初始化

// config/database.go
package configimport ("gorm.io/driver/mysql""gorm.io/gorm""log"
)var DB *gorm.DBfunc InitDB() {dsn := "root:password@tcp(127.0.0.1:3306)/test_db?charset=utf8mb4&parseTime=True&loc=Local"var err errorDB, err = gorm.Open(mysql.Open(dsn), &gorm.Config{})if err != nil {log.Fatal("连接数据库失败:", err)}
}

👤 六、数据模型定义(User)

// model/user.go
package modelimport "gorm.io/gorm"type User struct {gorm.ModelUsername string `gorm:"unique"`Password stringEmail    string
}

🔐 七、注册与登录接口(JWT鉴权)

注册接口

// controller/user.go
func Register(c *gin.Context) {var user model.Userif err := c.ShouldBindJSON(&user); err != nil {c.JSON(400, gin.H{"msg": "参数错误"})return}// 密码加密可使用 bcryptif err := config.DB.Create(&user).Error; err != nil {c.JSON(500, gin.H{"msg": "注册失败"})return}c.JSON(200, gin.H{"msg": "注册成功"})
}

登录接口(签发JWT)

func Login(c *gin.Context) {var input model.Uservar user model.Userif err := c.ShouldBindJSON(&input); err != nil {c.JSON(400, gin.H{"msg": "参数错误"})return}config.DB.Where("username = ? AND password = ?", input.Username, input.Password).First(&user)if user.ID == 0 {c.JSON(401, gin.H{"msg": "用户名或密码错误"})return}token, _ := utils.GenerateToken(user.Username) // 自定义方法生成JWTc.JSON(200, gin.H{"token": token})
}

📜 八、分页查询接口示例

func ListUsers(c *gin.Context) {var users []model.Userpage, _ := strconv.Atoi(c.DefaultQuery("page", "1"))pageSize := 10offset := (page - 1) * pageSizeconfig.DB.Offset(offset).Limit(pageSize).Find(&users)c.JSON(200, users)
}

🧱 九、中间件:JWT 鉴权中间件

func JWTAuthMiddleware() gin.HandlerFunc {return func(c *gin.Context) {tokenStr := c.GetHeader("Authorization")// 解析 token,验证签名claims, err := utils.ParseToken(tokenStr)if err != nil {c.AbortWithStatusJSON(401, gin.H{"msg": "未登录或令牌无效"})return}c.Set("username", claims.Username)c.Next()}
}

🔀 十、路由注册

// router/router.go
func InitRouter() *gin.Engine {r := gin.Default()r.POST("/register", controller.Register)r.POST("/login", controller.Login)auth := r.Group("/api", middleware.JWTAuthMiddleware()){auth.GET("/users", controller.ListUsers)// 其他增删改查}return r
}

🚀 十一、启动项目

// main.go
func main() {config.InitDB()r := router.InitRouter()r.Run(":8080")
}

✅ 十二、项目运行效果预览

使用 [Postman] 或 [curl] 调用如下接口:

  • POST /register 注册
  • POST /login 登录获取 JWT
  • GET /api/users 使用 JWT 鉴权获取分页用户列表

🧠 十三、可拓展方向

  • 接入 Casbin 做 RBAC 权限管理
  • 接入 Swagger 生成接口文档
  • 接入 Redis 做缓存与限流
  • 部署:打包成 Docker 镜像,发布到 K8s
  • 接入 go-zero 构建微服务架构

📚 学完你能收获什么?

  • 掌握 Gin + GORM 的完整开发流程
  • 理解分层架构,增强代码可维护性
  • 掌握 JWT 鉴权机制、分页、热重载等常见功能
  • 拥有一个完整、可拓展的 Golang 后端项目模板

Golang全栈开发,猛戳这里

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

相关文章:

  • 使用 C/C++ 和 OpenCV 判断是否抬头
  • Spring 事务传播行为详解
  • 自己的服务器被 DDOS跟CC攻击了怎么处理,如何抵御攻击?
  • 公司内网远程访问配置教程:本地服务器(和指定端口应用)实现外网连接使用
  • 29-Oracle 23ai Flashback Log Placement(闪回日志灵活配置)
  • 进程控制
  • Trae Builder 模式:从需求到全栈项目的端到端实践
  • 书写时垂直笔画比水平笔画表现更好的心理机制分析
  • Android binder内核漏洞研究(一)——环境搭建
  • 【MySQL基础】表的约束的类型与使用指南
  • 从Apache OFBiz 17.12.01的反序列化漏洞到Docker逃逸的渗透之红队思路
  • GaussDB 分布式数据库调优(架构到全链路优化)
  • C#实战:解决NPOI读取Excel单元格数值0.00001显示为1E-05的问题
  • [特殊字符] Harmony OS Next里的Web组件:网页加载的全流程掌控手册
  • macOS 查看当前命令行的ruby的安装目录
  • 大语言模型的分类与top3
  • Spark 之 Subquery
  • matlab实现非线性Granger因果检验
  • 深度学习:PyTorch张量基本运算、形状改变、索引操作、升维降维、维度转置、张量拼接
  • 将后端数据转换为docx文件
  • 京东零售基于Flink的推荐系统智能数据体系 |Flink Forward Asia 峰会实录分享
  • 论文阅读:arxiv 2025 How Likely Do LLMs with CoT Mimic Human Reasoning?
  • 自动化模型管理:MediaPipe Android SDK 中的模型文件下载与加载机制
  • Flutter:步骤条组件
  • Wi-Fi 6 在 2.4GHz 频段的速率与优化分析
  • Unit 3 训练一个Q-Learning智能体 Frozen-Lake-v1
  • 基于springboot视频及游戏管理系统+源码+文档+应用视频
  • RTP MOS计算:语音质量的数字评估
  • STM32HAL库发送字符串,将uint8_t数据转为字符串发送,sprintf函数的使用方法
  • 声学成像仪在电力行业的应用品牌推荐