2. Gin路由分组

为方便对一组路由设置统一规则,Gin支持对路由分组。

路由分成两类,一类是用户操作类user、一类是菜单操作类menu

package main

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

func main() {
	r := gin.Default()

	userGroup := r.Group("/user")
	userGroup.GET("/ping", func(c *gin.Context) {
		c.JSON(200, "OK")
	})

	menuGroup := r.Group("/menu")
	menuGroup.GET("/ping", func(c *gin.Context) {
		c.JSON(200, "OK")
	})

	r.Run() // 监听并在 0.0.0.0:8080 上启动服务
}

上面定义两个组,一个是userGroup,所有的路由以/user开头,另一个是menuGroup,所有的路由以menu开头,使用localhost:8080/user/ping 访问。

后续我们还会讲到基于Group进行middleware策略管理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果你在使用Go语言的Gin框架时没有进入`sockjs.NewHandler`处理程序,可能是由于路由配置不正确导致的。以下是一个示例代码,演示如何在Gin中正确配置SockJS处理程序: ```go package main import ( "log" "net/http" "github.com/gin-gonic/gin" "github.com/igm/sockjs-go/sockjs" ) func main() { // 创建Gin路由引擎 router := gin.Default() // 创建SockJS处理程序 handler := sockjs.NewHandler("/sockjs", sockjs.DefaultOptions, echoHandler) // 设置路由和处理程序 router.GET("/sockjs/*any", gin.WrapH(handler)) router.GET("/", homeHandler) // 启动HTTP服务器 err := router.Run(":8080") if err != nil { log.Fatal("Server start failed:", err) } } // 处理SockJS连接的函数 func echoHandler(session sockjs.Session) { for { if msg, err := session.Recv(); err == nil { // 处理接收到的消息,并发送回复 err := session.Send(msg) if err != nil { log.Println("Send message failed:", err) break } } else { log.Println("Receive message failed:", err) break } } } // 处理主页的函数 func homeHandler(c *gin.Context) { c.String(http.StatusOK, "Welcome to the homepage!") } ``` 在上述代码中,我们使用了Gin框架来构建Web应用。首先,创建了一个Gin路由引擎。然后,创建了SockJS处理程序,并将其包装为Gin的处理器函数(使用`gin.WrapH`函数)。接下来,我们使用`router.GET`方法来设置SockJS的路由。注意,这里的路由路径需要匹配SockJS的URL模式,可以使用`/*any`通配符来匹配任意路径。同时,我们还设置了处理主页的路由。 最后,调用`router.Run`启动HTTP服务器,并监听在8080端口上。 确保将SockJS处理程序正确绑定到路由上,以便在访问该路径时能够进入SockJS处理程序。在示例中,我们使用了`/sockjs/*any`作为SockJS的路由。 在你的实际代码中,你可能需要根据需求进行适当的修改和扩展。确保SockJS处理程序的路由配置正确,以便进入`sockjs.NewHandler`处理程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

明神特烦恼

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

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

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

打赏作者

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

抵扣说明:

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

余额充值