Gin学习记录2——路由

一. 常规路由

package main

import (
	"net/http"

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

func index(ctx *gin.Context) {
	ctx.String(http.StatusOK, "Hello Gin")
}

func main() {
	r := gin.Default()
	r.GET("/", index)
	r.Run(":80")
}

此时访问http://localhost/即可得到:
在这里插入图片描述

二. 动态路由

func uid(ctx *gin.Context) {
	userid := ctx.Param("uid")
	ctx.String(http.StatusOK, "User ID is: "+userid)
}

r.GET("/:uid", uid)

在这里插入图片描述

  • 缺点是不能像Django那样指定参数类型,这个

三. 带参数的路由

3.1 GET

对于GET方式的参数,咱们可以使用Query系列的操作

func (c *Context) Query(key string) (value string)
func (c *Context) QueryArray(key string) (values []string)
func (c *Context) QueryMap(key string) (dicts map[string]string)
func (c *Context) DefaultQuery(key, defaultValue string) string

例子:

	r.GET("/AddInt", func(ctx *gin.Context) {
		num := ctx.Query("num")
		opt := ctx.DefaultQuery("option", "GET")
		ctx.String(http.StatusOK, "num is %s option is %s", num, opt)
	})

在这里插入图片描述

3.2 POST

POST同理

func (c *Context) DefaultPostForm(key, defaultValue string) string
func (c *Context) PostForm(key string) (value string)
func (c *Context) PostFormArray(key string) (values []string)
func (c *Context) PostFormMap(key string) (dicts map[string]string)

3.3 绑定

通过绑定,可以将各种数据绑定到各种对象上

func (c *Context) ShouldBind(obj any) error
func (c *Context) ShouldBindBodyWith(obj any, bb binding.BindingBody) (err error)
func (c *Context) ShouldBindHeader(obj any) error
func (c *Context) ShouldBindJSON(obj any) error
func (c *Context) ShouldBindQuery(obj any) error
func (c *Context) ShouldBindTOML(obj any) error
func (c *Context) ShouldBindUri(obj any) error
func (c *Context) ShouldBindWith(obj any, b binding.Binding) error
func (c *Context) ShouldBindXML(obj any) error
func (c *Context) ShouldBindYAML(obj any) error

例如:

type AddType struct {
	Num1 string
	Num2 string
}

func main() {
	r := gin.Default()
	r.GET("/AddInt", func(ctx *gin.Context) {
		var num AddType
		if err := ctx.ShouldBind(&num); err == nil {
			ctx.String(http.StatusOK, "num1 is %s num2 is %s", num.Num1, num.Num2)
		} else {
			ctx.String(http.StatusBadRequest, "Error")
		}
	})
	r.Run(":80")
}

在这里插入图片描述
但是空成员也不会报错:
在这里插入图片描述

四. 简单的路由组

	v1 := r.Group("/v1")
	{
		v1.GET("/login", func(ctx *gin.Context) {
			ctx.String(http.StatusOK, "Success")
		})
	}
	v2 := r.Group("/v2")
	{
		v2.POST("/login", func(ctx *gin.Context) {
			ctx.String(http.StatusOK, "Success")
		})
	}

在这里插入图片描述

五. 文件分组

新建文件夹routers,并且在该文件夹下将路由分为两个:v1.gov2.go

package routers

import (
	"net/http"

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

func V1RoutesInit(router *gin.Engine) {
	v1Router := router.Group("/v1")
	{
		v1Router.GET("/user", func(c *gin.Context) {
			c.String(http.StatusOK, "v1查询")
		})
	}
}
package routers

import (
	"net/http"

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

func V2RoutesInit(router *gin.Engine) {
	v2Router := router.Group("/v2")
	{
		v2Router.GET("/user", func(c *gin.Context) {
			c.String(http.StatusOK, "v2查询")
		})
	}
}

然后在main.go里:imort moudel/package ,比如"kanna-web/routers"
然后即可调用:

	routers.V1RoutesInit(r)
	routers.V2RoutesInit(r)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Gin框架中,路由解析是通过路由引擎来实现的。Gin使用httprouter作为默认的路由引擎,该引擎基于Radix树实现快速的路由匹配。 当你在Gin应用程序中定义路由时,通过调用`gin.Engine`的`GET`、`POST`、`PUT`、`DELETE`等方法来注册不同的HTTP方法的路由处理函数。例如: ```go router := gin.Default() router.GET("/users/:id", getUserHandler) ``` 在路由路径中,可以使用冒号(:)来定义参数,例如`:id`表示一个名为"id"的参数。当请求到达时,Gin会将请求的URL与注册的路由进行匹配。 Gin路由引擎解析过程如下: 1. Gin首先将注册的路由表中的每个路由路径解析成一棵树,并构建相应的路由节点。 2. 当有新的请求到达时,Gin会从根节点开始遍历路由树。 3. 对于每个节点,Gin会检查节点的路径是否与当前请求的URL路径匹配。如果匹配成功,则继续遍历该节点的子节点。 4. 如果节点是参数节点(包含冒号(:)),则将该参数值提取出来,并将其作为上下文的一部分存储起来。 5. 当遍历到叶子节点时,找到了与请求URL完全匹配的路由路径。 6. Gin将找到的路由路径对应的处理函数返回给HTTP服务器,进行后续的处理。 需要注意的是,Gin路由引擎是基于树的数据结构,因此它具有较高的匹配效率和性能。 希望这个回答对你有帮助!如果你还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

康娜喵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值