基本的路由注册

下面最基础的gin路由注册方式,适用于路由条目比较少的简单项目或者项目demo。

package main

import (
"net/http" "github.com/gin-gonic/gin"
) func helloHandler(c *gin.Context) {
c.JSON(http.StatusOK, gin.H{
"message": "Hello mayanan.cn",
})
} func main() {
r := gin.Default()
r.GET("/topgoer", helloHandler)
if err := r.Run(); err != nil {
fmt.Println("startup service failed, err:%v\n", err)
}
}

路由拆分成单独文件或包

当项目的规模增大后就不太适合继续在项目的main.go文件中去实现路由注册相关逻辑了,我们会倾向于把路由部分的代码都拆分出来,形成一个单独的文件或包:

  1. 我们在routers.go文件中定义并注册路由信息:
package main

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

func helloHandler(context *gin.Context) {
context.JSON(200, "OK")
} func SetupRouter() *gin.Engine {
// 配置路由信息
router := gin.Default()
router.GET("/", helloHandler)
return router
}
  1. main.go中调用上面定义好的setupRouter函数:
package main

import "fmt"

func main() {
router := SetupRouter()
if err := router.Run(); err != nil {
fmt.Println(err)
return
}
}

此时的目录结构:

把路由部分的代码单独拆分成包的话也是可以的,拆分后的目录结构如下:

路由拆分成多个文件

当我们的业务规模继续膨胀,单独的一个routers文件或包已经满足不了我们的需求了,

func SetupRouter() *gin.Engine {
r := gin.Default()
r.GET("/topgoer", helloHandler)
r.GET("/xx1", xxHandler1)
...
r.GET("/xx30", xxHandler30)
return r
}

因为我们把所有的路由注册都写在一个SetupRouter函数中的话就会太复杂了。

我们可以分开定义多个路由文件,例如:

routers/shop.go中添加一个LoadShop的函数,将shop相关的路由注册到指定的路由器:

package routers

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

func hello2Handler(context *gin.Context) {
context.JSON(200, "hello")
} func LoadShop(router *gin.Engine) {
// 配置路由信息
router.GET("/hello", hello2Handler)
}

routers/blog.go中添加一个LoadBlog的函数,将blog相关的路由注册到指定的路由器:

package routers

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

func helloHandler(context *gin.Context) {
context.JSON(200, "OK")
} func LoadBlog(router *gin.Engine) {
// 配置路由信息
router.GET("/", helloHandler)
}

在main函数中实现最终的注册逻辑如下:

package main

import (
"common_standard_library/routers"
"fmt"
"github.com/gin-gonic/gin"
) func main() {
router := gin.Default()
routers.LoadBlog(router)
routers.LoadShop(router)
if err := router.Run(); err != nil {
fmt.Println(err)
return
}
}

路由拆分到不同的app

有时候项目规模实在太大,那么我们就更倾向于把业务拆分的更详细一些,例如把不同的业务代码拆分成不同的APP。

因此我们在项目目录下单独定义一个app目录,用来存放我们不同业务线的代码文件,这样就很容易进行横向扩展。大致目录结构如下:

其中app/blog/router.go用来定义blog相关路由信息,具体内容如下:

package blog

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

func Routers(router *gin.Engine) {
router.GET("/blog", blog)
}

app/shop/router.go用来定义shop相关路由信息,具体内容如下:

package shop

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

func Routers(router *gin.Engine) {
router.GET("/blog", shop)
}

routers/routers.go中根据需要定义Include函数用来注册子app中定义的路由,Init函数用来进行路由的初始化操作:

package routers

import (
"github.com/gin-gonic/gin"
) type Option func(router *gin.Engine) var options = make([]Option, 0) // 注册app的路由配置
func Include(opts ...Option) {
options = append(options, opts...)
} // 初始化路由
func Init() *gin.Engine {
router := gin.Default()
for _, opt := range options {
opt(router)
}
return router
}

main.go中按如下方式先注册子app中的路由,然后再进行路由的初始化:

package main

import (
"common_standard_library/app/blog"
"common_standard_library/app/shop"
"common_standard_library/routers"
"fmt"
) func main() {
// 加载多个app的路由配置
routers.Include(blog.Routers, shop.Routers)
// 初始化路由
router := routers.Init() if err := router.Run(); err != nil {
fmt.Println(err)
return
}
}

参考链接:https://www.liwenzhou.com/posts/Go/gin_routes_registry/

路由拆分到不同app升级版-支持路由组(前台不变和后台路由自动加/admin用户)

  1. 目录结构

  2. 后台应用的router.go文件 app/shop/router.go

package shop

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

func Routers(router *gin.RouterGroup) {
router.GET("/shop", shop)
}
  1. routers/routers.go(增加了后台路由组)
点击查看代码
package routers

import (
"github.com/gin-gonic/gin"
) type Option func(router *gin.Engine)
type AdminOption func(adminRouterGroup *gin.RouterGroup) var options = make([]Option, 0)
var adminOptions = make([]AdminOption, 0) // 注册app的前台路由配置
func Include(opts ...Option) {
options = append(options, opts...)
} // 注册app的后台路由配置
func IncludeAdmin(adminOpts ...AdminOption) {
adminOptions = append(adminOptions, adminOpts...)
} // 初始化路由
func Init() *gin.Engine {
router := gin.Default()
adminRouterGroup := router.Group("/admin")
for _, opt := range options {
opt(router)
}
for _, adminOpt := range adminOptions {
adminOpt(adminRouterGroup)
}
return router
}
  1. main.py中增加了后台路由配置
package main

import (
"common_standard_library/app/blog"
"common_standard_library/app/shop"
"common_standard_library/routers"
"fmt"
) func main() {
// 加载app的前台路由配置
routers.Include(blog.Routers)
// 加载app的后台路由配置
routers.IncludeAdmin(shop.Routers)
// 初始化路由
router := routers.Init() if err := router.Run(); err != nil {
fmt.Println(err)
return
}
}

gin框架中的路由拆分与注册的更多相关文章

  1. gin框架中请求路由组的使用

    1. gin框架中可以使用路由组来实现对路由的分类 package main import "github.com/gin-gonic/gin" func main() { rou ...

  2. gin框架中的路由

    基本路由 gin框架中采用的路由库是基于httrouter做的 地址为:https://github.com/julienschmidt/httprouter httprouter路由库 点击查看代码 ...

  3. 在gin框架中使用JWT

    在gin框架中使用JWT JWT全称JSON Web Token是一种跨域认证解决方案,属于一个开放的标准,它规定了一种Token实现方式,目前多用于前后端分离项目和OAuth2.0业务场景下. 什么 ...

  4. gin框架路由拆分与注册

    gin框架路由拆分与注册 本文总结了我平时在项目中积累的关于gin框架路由拆分与注册的若干方法. gin框架路由拆分与注册 基本的路由注册 下面最基础的gin路由注册方式,适用于路由条目比较少的简单项 ...

  5. Gin 框架 - 安装和路由配置

    目录 概述 Gin 安装 路由配置 推荐阅读 概述 看下 Gin 框架的官方介绍: Gin 是一个用 Go (Golang) 编写的 web 框架. 它是一个类似于 martini 但拥有更好性能的 ...

  6. golang gin框架中实现一个简单的不是特别精确的秒级限流器

    起因 看了两篇关于golang中限流器的帖子: Gin 开发实践:如何实现限流中间件 常用限流策略--漏桶与令牌桶介绍 我照着用,居然没效果-- 时间有限没有深究.这实在是一个很简单的功能,我的需求是 ...

  7. gin框架中的参数验证

    结构体验证 用gin框架的数据验证,可以不用解析数据,减少if else,会简洁许多. 处理请求方法 func structValidator(context *gin.Context) { var ...

  8. 【解决了一个小问题】gin框架中出现如下错误:"[GIN-debug] [WARNING] Headers were already written. Wanted to override status code 400 with 500"

    POST到数据到一条gin框架的接口后,客户端收到400错误,并且返回了业务中返回的"decode json fail". 关键代码是: func report(c *gin.Co ...

  9. golang gin框架中实现大文件的流式上传

    一般来说,通过c.Request.FormFile()获取文件的时候,所有内容都全部读到了内存.如果是个巨大的文件,则可能内存会爆掉:且,有的时候我们需要一边上传一边处理. 以下的代码实现了大文件流式 ...

随机推荐

  1. Spring学习(三)几种集合属性的注入方式

    1.前言 众所周知.java中不只有八大简单类型.还有一些集合类型.本文围绕集合类型的注入做一个总结. 2.项目骨架 3.过程 1.创建实体类AllCollectionType package com ...

  2. MyBatis中比较(大于、小于)符号的转义写法

    <     < <=   <= >    > >=   >= &     & '     &apos; "     & ...

  3. nim_duilib(16)之xml学习实战(GTAV加载窗口实现)

    本文的目标 使用配置xml实现下面的结果 布局 整体采用水平布局,左边显示文字区域设置为垂直布局. lets go stage 1 创建一个空白窗体,并设置为半透明:同时,使得整个窗口可以移动,则 将 ...

  4. 【LeetCode】1413. 逐步求和得到正数的最小值 Minimum Value to Get Positive Step by Step Sum

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 求和 日期 题目地址:https://leetcode ...

  5. 1030 - Discovering Gold

    1030 - Discovering Gold    PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 M ...

  6. 1326 - Race

    1326 - Race   PDF (English) Statistics Forum Time Limit: 1 second(s) Memory Limit: 32 MB Disky and S ...

  7. C# RabbitMQ的使用

    本文目的如题. 安装 先说一下RabbitMQ的安装,建议使用Docker镜像安装,Docker安装的好处是不管Windows系统还是Linux,安装步骤少,安装方法相同,不容易出错.使用下面的命令就 ...

  8. 第六个知识点:我们怎么把NP问题解释成一组可以在多项式内证明的命题

    第六个知识点:我们怎么把NP问题解释成一组可以在多项式内证明的命题 原文地址:http://bristolcrypto.blogspot.com/2014/11/52-things-number-6- ...

  9. (五)React Ant Design Pro + .Net5 WebApi:后端环境搭建-Autofac注入+ 泛型仓储

    一. 简介 Autofac与.Net Core自带DI的区别,大佬级的文章数不胜数.我只是根据实际应用简单介绍(非常简单的那种) 1.批量注入,自带DI需要自己写循环反射注入,Autofac现成方法, ...

  10. HAproxy开启日志记录

    1.说明 HAproxy在默认情况不会记录日志, 不仅要在haproxy.conf中配置日志输出, 还需要修改系统日志的配置文件. 2.修改haproxy.conf 在haproxy.conf文件中增 ...