av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

創(chuàng)新互聯(lián)Gin教程:Gin中間件

Gin框架允許開發(fā)者在處理請求的過程中,加入鉤子函數(shù),這個鉤子函數(shù)就叫中間件。中間件適合處理一些公共的業(yè)務邏輯,比如登陸認證,權(quán)限校驗,記錄日志等。具體使用方法如下

在鐘樓等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站建設、網(wǎng)站制作 網(wǎng)站設計制作按需定制制作,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,高端網(wǎng)站設計,營銷型網(wǎng)站建設,外貿(mào)營銷網(wǎng)站建設,鐘樓網(wǎng)站建設費用合理。

package main

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

//定義一個中間鍵m1統(tǒng)計請求處理函數(shù)耗時
func m1(c *gin.Context) {
	fmt.Println("m1 in...")
	start := time.Now()
	// c.Next() //調(diào)用后續(xù)的處理函數(shù)
	c.Abort()//阻止調(diào)用后續(xù)的處理函數(shù)
	cost := time.Since(start)
	fmt.Printf("cost:%v\n", cost)
}

func index(c *gin.Context) {
	c.JSON(http.StatusOK, gin.H{
		"msg": "ok",
	})
}

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

在中間件中使用Goroutine

當在中間件或 handler 中啟動新的 Goroutine 時,不能使用原始的上下文,必須使用只讀副本。

package main

import (
	"github.com/gin-gonic/gin"
	"log"
	"time"
)

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

	r.GET("/long_async", func(c *gin.Context) {
		// 創(chuàng)建在 goroutine 中使用的副本
		tmp := c.Copy()
		go func() {
			// 用 time.Sleep() 模擬一個長任務。
			time.Sleep(5 * time.Second)

			// 請注意您使用的是復制的上下文 "tmp",這一點很重要
			log.Println("Done! in path " + tmp.Request.URL.Path)
		}()
	})

	r.GET("/long_sync", func(c *gin.Context) {
		// 用 time.Sleep() 模擬一個長任務。
		time.Sleep(5 * time.Second)

		// 因為沒有使用 goroutine,不需要拷貝上下文
		log.Println("Done! in path " + c.Request.URL.Path)
	})
	r.Run()
}

標題名稱:創(chuàng)新互聯(lián)Gin教程:Gin中間件
網(wǎng)站網(wǎng)址:http://uogjgqi.cn/article/cdejdoe.html
掃二維碼與項目經(jīng)理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流