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",
	})
}
相关推荐
warm3snow4 小时前
Claude Code 黑客马拉松:5 个获奖项目,没有一个是"纯码农"做的
ai·大模型·llm·agent·skill·mcp
马腾化云东9 小时前
Agent开发应知应会(langfuse):Langfuse Score概念详解和实战应用
人工智能·llm·ai编程
Baihai_IDP10 小时前
HackerNews 热榜第一名:AGI 的 A,原来代表的是 Ads(广告)
人工智能·程序员·llm
吴佳浩12 小时前
OpenClaw Windows 完整安装与本地模型配置教程(实战版)
llm·openai
刀法如飞1 天前
一款Go语言Gin框架MVC脚手架,满足大部分场景
go·mvc·gin
吴佳浩2 天前
《大模型的文件形态:Qwen3 文件结构与计算流程深度拆解》
人工智能·llm
花酒锄作田2 天前
Gin 框架中的规范响应格式设计与实现
golang·gin
郑州光合科技余经理2 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1232 天前
matlab画图工具
开发语言·matlab
EdisonZhou2 天前
MAF快速入门(17)用户智能体交互协议AG-UI(中)
llm·aigc·agent