go gin middleware中间件 time.Since(start)

6 篇文章 0 订阅
  • 中间件使用者从大到小可以分为3个:
    所有路由使用:r := gin.Default();r.Use(midware1,midware2)
    路由组:g1:=r.Group("/g1");g1.Use(midware1,midware1)
    单个路由使用:r.GET("/m1", midware1, midware2, handler1)
    参数里可以添加任意个中间件
  • 如果在某个中间件内部调用了c.Next(),会提前调用下一个中间件,等处理完之后的所有中间件和handler之后,继续执行本中间件c.Next()之后的代码。如果没有调用c.Next(),可认为会在当前中间件return之前调用c.Next()
  • 如果在某个中间件内部调用了c.Abort(),之后的中间件和handler都不再被调用
  • 如果在某个中间件内部做了重定向,页面会进行重定向,但之后的中间件和handler还是会被调用。重定向前建议加上abort
  • 中间件传值:先执行的中间件c.Set(key,val),再后执行的中间件c.Get(key)即可。val可以是任意类型,如果没有值返回nil
  • start:=time.Now();*******;time.Since(start)可以计算间隔的数据
pacpackage main

import (
	"fmt"
	"html/template"
	"log"
	"mime/multipart"
	"net/http"
	"path"
	"time"
	"github.com/gin-gonic/gin"
)

func main() {
	mainGin()
}

type UserInfo struct {
	Name   string
	Gender bool
	Age    int
}

func midware1(c *gin.Context) {
	log.Println("m1 start>>")
	start:=time.Now()
	c.Set("person",UserInfo{"柯南",true,6})
	//next调用后续的 处理函数/中间件
	c.Next()
	// c.Abort()
	// c.JSON(http.StatusOK,gin.H{"return at":"m1"})
	// return
	// c.Redirect(http.StatusPermanentRedirect,"/b2")
	log.Println("<<m1 end",time.Since(start))
}


func midware2(c *gin.Context) {
	log.Println("m2 start>>")
	userInfo,ok:=c.Get("person")
	if ok || !ok{
		fmt.Printf("%v",userInfo)
	}
	// c.Next()
	log.Println("<<m2 end")
}

func handler1(c *gin.Context) {
	log.Println("h1 start>>")
	c.JSON(http.StatusOK, gin.H{"msg": "test middleware"})
	log.Println("<<h1 end")
}
func mainGin() {
	r := gin.Default()
	r.LoadHTMLFiles(******************)
	
	// r.Use(midware1,midware2)

	// 访问/m1输出如下,
	// m1 start>>
	// m2 start>>
	// h1 start>>
	// <<h1 end
	// <<m2 end
	// <<m1 end
	r.GET("/m1", midware1, midware2,  handler1)
	r.GET("/m2", midware2, midware1,  handler1)

	g1 := r.Group("/g1")
	// g1.Use(midware1)
	{
		// get /g1/1
		g1.GET("/1", func(c *gin.Context) {
			c.JSON(http.StatusOK, gin.H{"msg": "g11"})
		})
		// post /g1/2
		g1.POST("/2", func(c *gin.Context) {
			c.JSON(http.StatusOK, gin.H{"msg": "g12"})
		})
		// get /g1/g2/1
		g2 := g1.Group("/g2")
		// g2.Use(midware2,midware2)
		{
			g2.GET("/3", func(c *gin.Context) {
				c.JSON(http.StatusOK, gin.H{"msg": "g23"})
			})
		}
	}

  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值