Gin(四) 基本路由和路由组

Gin 路由

1. 基本路由

  • gin 框架采用的路由库是基于 httprouter做的
  • 其基本原理就是构造一个路由地址的前缀树。
r.GET("/index", func(c *gin.Context) {...})
r.GET("/login", func(c *gin.Context) {...})
r.POST("/login", func(c *gin.Context) {...})

Any 匹配所有请求

r.Any("/test", func(c *gin.Context) {...})

//源码
// Any registers a route that matches all the HTTP methods.
// GET, POST, PUT, PATCH, HEAD, OPTIONS, DELETE, CONNECT, TRACE.
func (group *RouterGroup) Any(relativePath string, handlers ...HandlerFunc) IRoutes {
	group.handle(http.MethodGet, relativePath, handlers)
	group.handle(http.MethodPost, relativePath, handlers)
	group.handle(http.MethodPut, relativePath, handlers)
	group.handle(http.MethodPatch, relativePath, handlers)
	group.handle(http.MethodHead, relativePath, handlers)
	group.handle(http.MethodOptions, relativePath, handlers)
	group.handle(http.MethodDelete, relativePath, handlers)
	group.handle(http.MethodConnect, relativePath, handlers)
	group.handle(http.MethodTrace, relativePath, handlers)
	return group.returnObj()
}

为不匹配的路由设置处理函数,默认情况下它返回404代码

r.NoRoute(func(ctx *gin.Context) {...})

// 源码
// NoRoute adds handlers for NoRoute. It return a 404 code by default.
func (engine *Engine) NoRoute(handlers ...HandlerFunc) {
    engine.noRoute = handlers
    engine.rebuild404Handlers()
}

2.路由组

为了管理具有相同前缀的URL, 将拥有URL共同前缀的路由划分为一组

为了代码的阅读性,使用{}包裹相同组的路由不用{}包裹并不影响效果

package main

import (
	"github.com/gin-gonic/gin"
	"net/http"
)

/**
    路由组:
     将拥有URL共同前缀的路由划分为一组, 为了代码的阅读性,使用{}包裹相同组的路由不用{}包裹并不影响效果
 */
func main() {

	// 创建路由
	r := gin.Default()

	// 绑定路由规则
	userGroup := r.Group("/user") 
	{
		// /user/home
		userGroup.GET("/home", func(ctx *gin.Context) {
			ctx.JSON(http.StatusOK,  "/user/home")
		})
		// /user/login
		userGroup.GET("/login", func(ctx *gin.Context) {
			ctx.JSON(http.StatusOK, "/user/login")
		})
	}

	// 绑定路由规则
	shopGroup := r.Group("/shop")
	{
		// /shop/info
		shopGroup.GET("/info", func(ctx *gin.Context) {
			ctx.JSON(http.StatusOK,  "/shop/info")
		})
		// /shop/cart
		shopGroup.GET("/cart", func(ctx *gin.Context) {
			ctx.JSON(http.StatusOK, "/shop/cart")
		})
	}

	// 监听端口
	r.Run(":9000")
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3. 路由组嵌套

// 绑定路由规则
shopGroup := r.Group("/shop")
{
    // shop/book
    shopBookGroup := shopGroup.Group("/book")

    // shop/book/info
    shopBookGroup.GET("/info", func(ctx *gin.Context) {
        ctx.JSON(http.StatusOK, "shop/book/info")
    })
}

在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Go语言中,可以使用Gin框架来进行路由的模糊匹配。Gin框架提供了`Group`和`Any`方法来实现路由的模糊匹配。以下是一个简单的示例: ```go package main import ( "github.com/gin-gonic/gin" ) func main() { router := gin.Default() router.GET("/users", getUsers) router.GET("/users/:id", getUserByID) // 使用 Group 进行模糊匹配 v1 := router.Group("/v1") { v1.GET("/products", getProducts) v1.GET("/products/:id", getProductByID) } router.Run(":8080") } func getUsers(c *gin.Context) { c.JSON(200, gin.H{ "message": "Get all users", }) } func getUserByID(c *gin.Context) { id := c.Param("id") c.JSON(200, gin.H{ "message": "Get user by ID", "id": id, }) } func getProducts(c *gin.Context) { c.JSON(200, gin.H{ "message": "Get all products", }) } func getProductByID(c *gin.Context) { id := c.Param("id") c.JSON(200, gin.H{ "message": "Get product by ID", "id": id, }) } ``` 在上面的例子中,我们使用了`router.GET`方法来定义了一些基本路由,如`/users`和`/users/:id`。然后,我们使用`Group`方法创建了一个路由`v1`,并在该路由内定义了一些模糊匹配的路由,如`/v1/products`和`/v1/products/:id`。 通过使用路由,我们可以实现对指定路由路径的前缀或者模式进行匹配,从而实现模糊匹配的效果。 需要注意的是,Gin框架还提供了`Any`方法,可以用于匹配所有HTTP方法(GET、POST、PUT、DELETE等)。你可以根据实际需求选择合适的方法来实现模糊匹配。同时,你还可以使用通配符`*`来匹配多级路径,如`/users/*action`可以匹配`/users/get`, `/users/add`等路径。 以上示例只是一个简单的演示,你可以根据实际需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值