Gin版本的路由总结

之前做算法,一直使用fastapi,进行算法集成数据库,知识库,以及向量数据库,最近为了减轻自己的工作量,索性更换了底层框架,该用gin,实现了单人开发,算法,前后端,每一个版本直接交付,不需要服务器部署等繁琐操作,特别适合公司算法就1个,也不需要和别人写作的情景下开发。基于此,整理了下gin的路由模块,发现和fastapi还是很相似的非常好用。

1.目录结构
2. 代码部分
2.1. main.go
复制代码
package main

import (
	"gowebui/routers"
)
func main(){
	// 设置路由
	r := routers.SetupRouter()
	// 启动服务器
	r.Run(":8080")

	
}
2.2. routers
2.2.1. router/routers.go
复制代码
// routers/routers.go
package routers

import (

	// v1 路由模块

	v1 "gowebui/routers/v1"
	"net/http"

	"github.com/gin-gonic/gin"
)

// SetupRouter 初始化路由引擎
func SetupRouter() *gin.Engine {
	// 根据配置设置 Gin 运行模式
	

	// 创建默认的 Gin 引擎
	r := gin.Default()

	// 设置静态资源路由:/static/* -> ./web/static/
	// r.Static("/static", "./web/static")

	// 加载 HTML 模板:支持嵌套模板(如 layout + page)
	// r.LoadHTMLGlob("./web/templates/*")

	// 注册首页路由(如果是 Web 页面)
	// r.GET("/", controller.IndexHandler)

	// 可选:健康检查
	r.GET("/ping", func(c *gin.Context) {
		c.String(http.StatusOK, "pong")
	})

	// 挂载 API 版本路由
	// 由于 v1.SetupTodoRoutes 未定义,暂时注释掉该调用,需检查 v1 包中是否存在该函数
	v1.RegisterRoutes(r) // 推荐方式:调用 v1 包注册
	// 或直接调用 setupTodoRoutes(r)(见下方备选)

	return r
}
2.2.2. routers/v1/register.go
复制代码
// routers/v1/register.go
package v1

import "github.com/gin-gonic/gin"

// RegisterRoutes 注册 v1 版本的所有路由
func RegisterRoutes(r *gin.Engine) {
	v1 := r.Group("/v1")
	{
		setupTodoRoutes(v1)
		setupUserRoutes(v1)
		// 其他模块...
	}
}
2.2.3. routers/v1/user.go
复制代码
// routers/v1/todo.go
package v1

import (
	"gowebui/controller"

	"github.com/gin-gonic/gin"
)

func setupUserRoutes(rg *gin.RouterGroup) {
	todo := rg.Group("/todo")
	{
		// todo.POST("", controller.CreateTodo)           // POST /v1/todo
		todo.GET("", controller.GetUserList)           // GET /v1/todo
		todo.GET("/:id", controller.GetUser)           // GET /v1/todo/1
		// todo.PUT("/:id", controller.UpdateTodo)        // PUT /v1/todo/1
		// todo.DELETE("/:id", controller.DeleteTodo)     // DELETE /v1/todo/1
	}
}
2.2.4. routers/v1/todo.go
复制代码
package v1

import (
	"gowebui/controller"

	"github.com/gin-gonic/gin"
)

func setupTodoRoutes(r *gin.RouterGroup) {
	todo := r.Group("/user")
	{
		// todo.POST("", controller.CreateTodo)           // POST /v1/todo
		todo.GET("", controller.GetTodoList)           // GET /v1/todo
		todo.GET("/:id", controller.GetTodo)           // GET /v1/todo/1
		// todo.PUT("/:id", controller.UpdateTodo)        // PUT /v1/todo/1
		// todo.DELETE("/:id", controller.DeleteTodo)     // DELETE /v1/todo/1
	}
}
2.3. controller/controller.go
复制代码
package controller

import (
	"net/http"

	"github.com/gin-gonic/gin"
)


func GetUserList(c *gin.Context) {
	c.JSON(http.StatusOK, gin.H{
		"message": "GetUserList",
	})
}

func GetUser(c *gin.Context) {
	c.JSON(http.StatusOK, gin.H{
		"message": "GetUser",
	})
}




func GetTodoList(c *gin.Context) {
	c.JSON(http.StatusOK, gin.H{
		"message": "GetTodoList",
	})
}

func GetTodo(c *gin.Context) {
	c.JSON(http.StatusOK, gin.H{
		"message": "GetTodo",
	})
}
相关推荐
周杰伦_Jay3 小时前
【Eino框架】Go语言驱动的LLM应用开发新范式
开发语言·后端·golang
上78将3 小时前
Java中既有编译执行又有解释执行,这个怎么理解?
java·开发语言
一个无名的炼丹师3 小时前
【硬核实战】Python处理多源异构文档:从读取到智能信息提取的统一框架深度剖析
开发语言·python
Mr_Xuhhh3 小时前
JAVA期末重点
java·开发语言·python
a程序小傲3 小时前
小红书Java面试被问:java创建对象有哪些方式?
java·开发语言·面试
行走的陀螺仪4 小时前
JavaScript 装饰器完全指南(原理/分类/场景/实战/兼容)
开发语言·javascript·ecmascript·装饰器
CreasyChan4 小时前
C# 委托/事件/UnityEvent 详解
开发语言·c#
whm27774 小时前
Visual Basic 建立数据库
开发语言·数据库·visual studio
1024小神4 小时前
swift中使用ObservableObject单利模式的时候,用let 或 @ObservedObject 或 @StateObject 有什么区别
开发语言·ios·swift