chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

Go項目中引入中間件的目的和效果如何

阿銘linux ? 來源:思否開發(fā)者社區(qū) ? 作者:guyan0319 ? 2021-08-14 14:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

中間件是什么?Go 項目中引入中間件的目的和效果如何?本文詳細介紹了Golang 中間件。

中間件是一種計算機 軟件,可為 操作系統(tǒng) 提供的 軟件應用程序 提供服務,以便于各個軟件之間的溝通,特別是系統(tǒng)軟件和應用軟件。廣泛用于 web 應用和面向服務的體系結(jié)構(gòu)等。

縱觀 GO 語言,中間件應用比較普遍,主要應用:

記錄對服務器發(fā)送的請求(request)

處理服務器響應(response )

請求和處理之間做一個權(quán)限認證工作

遠程調(diào)用

安全

等等

中間件處理程序是簡單的http.Handler,它包裝另一個http.Handler做請求的一些預處理和/或后處理。它被稱為“中間件”,因為它位于 Go Web 服務器和實際處理程序之間的中間位置。

下面是一些中間件例子

記錄日志中間件

package main

import (

“fmt”

“l(fā)og”

“net/http”

func logging(f http.HandlerFunc) http.HandlerFunc {

return func(w http.ResponseWriter, r *http.Request) {

log.Println(r.URL.Path)

f(w, r)

}

}

func foo(w http.ResponseWriter, r *http.Request) {

fmt.Fprintln(w, “foo”)

}

func bar(w http.ResponseWriter, r *http.Request) {

fmt.Fprintln(w, “bar”)

}

func main() {

http.HandleFunc(“/foo”, logging(foo))

http.HandleFunc(“/bar”, logging(bar))

http.ListenAndServe(“:8080”, nil)

}

訪問 http://localhost:8080/foo

返回結(jié)果

foo

將上面示例修改下,也可以實現(xiàn)相同的功能。

package main

import (

“fmt”

“l(fā)og”

“net/http”

func foo(w http.ResponseWriter, r *http.Request) {

fmt.Fprintln(w, “foo”)

}

func bar(w http.ResponseWriter, r *http.Request) {

fmt.Fprintln(w, “bar”)

}

func loggingMiddleware(next http.Handler) http.Handler {

return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {

log.Println(r.URL.Path)

next.ServeHTTP(w, r)

})

}

func main() {

http.Handle(“/foo”, loggingMiddleware(http.HandlerFunc(foo)))

http.Handle(“/bar”, loggingMiddleware(http.HandlerFunc(bar)))

http.ListenAndServe(“:8080”, nil)

}

訪問 http://localhost:8080/foo

返回結(jié)果

foo

多中間件例子

package main

import (

“fmt”

“l(fā)og”

“net/http”

time”

type Middleware func(http.HandlerFunc) http.HandlerFunc// Logging logs all requests with its path and the time it took to processfunc Logging() Middleware {

// Create a new Middleware

return func(f http.HandlerFunc) http.HandlerFunc {

// Define the http.HandlerFunc

return func(w http.ResponseWriter, r *http.Request) {

// Do middleware things

start := time.Now()

defer func() { log.Println(r.URL.Path, time.Since(start)) }()

// Call the next middleware/handler in chain

f(w, r)

}

}

}

// Method ensures that url can only be requested with a specific method, else returns a 400 Bad Requestfunc Method(m string) Middleware {

// Create a new Middleware

return func(f http.HandlerFunc) http.HandlerFunc {

// Define the http.HandlerFunc

return func(w http.ResponseWriter, r *http.Request) {

// Do middleware things

if r.Method != m {

http.Error(w, http.StatusText(http.StatusBadRequest), http.StatusBadRequest)

return

}

// Call the next middleware/handler in chain

f(w, r)

}

}

}

// Chain applies middlewares to a http.HandlerFuncfunc Chain(f http.HandlerFunc, middlewares 。。.Middleware) http.HandlerFunc {

for _, m := range middlewares {

f = m(f)

}

return f

}

func Hello(w http.ResponseWriter, r *http.Request) {

fmt.Fprintln(w, “hello world”)

}

func main() {

http.HandleFunc(“/”, Chain(Hello, Method(“GET”), Logging()))

http.ListenAndServe(“:8080”, nil)

}

中間件本身只是將其http.HandlerFunc作為其參數(shù)之一,包裝它并返回一個新http.HandlerFunc的服務器來調(diào)用。在這里,我們定義了一種新類型Middleware,最終可以更容易地將多個中間件鏈接在一起。

當然我們也可以改成如下形式

package main

import (

“fmt”

“l(fā)og”

“net/http”

“time”

type Middleware func(http.Handler) http.Handlerfunc Hello(w http.ResponseWriter, r *http.Request) {

fmt.Fprintln(w, “hello world”)

}

func Chain(f http.Handler, mmap 。。.Middleware) http.Handler {

for _, m := range mmap {

f = m(f)

}

return f

}

func Method(m string) Middleware {

return func(f http.Handler) http.Handler {

return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {

log.Println(r.URL.Path)

if r.Method != m {

http.Error(w, http.StatusText(http.StatusBadRequest), http.StatusBadRequest)

return

}

f.ServeHTTP(w, r)

})

}

}

func Logging() Middleware {

return func(f http.Handler) http.Handler {

return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {

//log.Println(r.URL.Path)

// Do middleware things

start := time.Now()

defer func() { log.Println(r.URL.Path, time.Since(start)) }()

f.ServeHTTP(w, r)

})

}

}

func main() {

http.Handle(“/”, Chain(http.HandlerFunc(Hello), Method(“GET”), Logging()))

http.ListenAndServe(“:8080”, nil)

}

在 gin 框架下實現(xiàn)中間件

r := gin.Default() 創(chuàng)建帶有默認中間件的路由,默認是包含 logger 和 recovery 中間件的

r :=gin.new() 創(chuàng)建帶有沒有中間件的路由

示例

package main

import (

“github.com/gin-gonic/gin”

“l(fā)og”

“time”

func Logger() gin.HandlerFunc {

return func(c *gin.Context) {

t := time.Now()

// Set example variable

c.Set(“example”, “12345”)

// before request

c.Next()

// after request

latency := time.Since(t)

log.Print(latency) //時間 0s

// access the status we are sending

status := c.Writer.Status()

log.Println(status) //狀態(tài) 200

}

}

func main() {

r := gin.New()

r.Use(Logger())

r.GET(“/test”, func(c *gin.Context) {

example := c.MustGet(“example”)。(string)

// it would print: “12345”

log.Println(example)

})

// Listen and serve on 0.0.0.0:8080

r.Run(“:8080”)

}

以上示例也可改為

package main

import (

“github.com/gin-gonic/gin”

“l(fā)og”

“time”

func Logger() gin.HandlerFunc {

return func(c *gin.Context) {

t := time.Now()

// Set example variable

c.Set(“example”, “12345”)

// before request

c.Next()

// after request

latency := time.Since(t)

log.Print(latency) //時間 0s

// access the status we are sending

status := c.Writer.Status()

log.Println(status) //狀態(tài) 200

}

}

func main() {

r := gin.New()

r.GET(“/test”, Logger(), func(c *gin.Context) {

example := c.MustGet(“example”)。(string)

// it would print: “12345”

log.Println(example)

})

// Listen and serve on 0.0.0.0:8080

r.Run(“:8080”)

}

即不用 r.use 添加中間件,直接將 Logger() 寫到 r.GET 方法的參數(shù)里(“/test”之后)。

更多 gin 中間件示例可參考 https://github.com/gin-gonic/gin

轉(zhuǎn)自:guyan0319

segmentfault.com/a/1190000018819804

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Web
    Web
    +關注

    關注

    2

    文章

    1304

    瀏覽量

    74478
  • 計算機
    +關注

    關注

    19

    文章

    7807

    瀏覽量

    93205
  • 服務器
    +關注

    關注

    14

    文章

    10253

    瀏覽量

    91502

原文標題:GO 中間件 Middleware

文章出處:【微信號:aming_linux,微信公眾號:阿銘linux】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    谷景DLCHX工字電感在智能插座項目中的應用

    在全球供應鏈格局深度調(diào)整的背景下,電感的國產(chǎn)化替代已成為眾多企業(yè)提升供應鏈韌性、控制成本、確保交期的戰(zhàn)略選擇。近期,谷景成功協(xié)助上海某智能設備客戶,完成其智能插座項目中關鍵電感元件的國產(chǎn)化替代,從技術匹配到風險預防,全程護航項目順利量產(chǎn)。
    的頭像 發(fā)表于 02-28 09:19 ?542次閱讀

    以“網(wǎng)關中間件”實現(xiàn)充電樁OCPP 1.6安全配置文件無縫升級

    深圳惠志科技有限公司推出的OCPP安全代理網(wǎng)關采用"網(wǎng)關中間件"架構(gòu),在充電樁與云端CSMS之間透明地部署,實現(xiàn)充電樁OCPP 1.6協(xié)議安全配置文件從Profile 0/1到Profile 2/3的無縫升級,而無需觸及樁端硬件與固件。
    的頭像 發(fā)表于 02-04 11:56 ?818次閱讀
    以“網(wǎng)關<b class='flag-5'>中間件</b>”實現(xiàn)充電樁OCPP 1.6安全配置文件無縫升級

    博泰車聯(lián)網(wǎng)攜手產(chǎn)業(yè)伙伴共建天元OS開源生態(tài)

    近日,2025中國汽車軟件大會于上海嘉定召開。會上,行業(yè)首個覆蓋自動駕駛?cè)珬5拈_源中間件——“天元OS跨域中間件”正式以全棧開源的形式發(fā)布。博泰車聯(lián)作為項目核心共建單位受邀參與,與產(chǎn)業(yè)伙伴共同見證并推動中國智能汽車基礎軟件邁向開
    的頭像 發(fā)表于 12-31 14:41 ?485次閱讀

    黑芝麻智能攜手產(chǎn)業(yè)伙伴共建天元OS開源生態(tài)

    2025中國汽車軟件大會期間,行業(yè)首個覆蓋自動駕駛?cè)珬5拈_源中間件——天元OS跨域中間件正式全棧開源發(fā)布,黑芝麻智能作為共建單位出席啟動儀式。
    的頭像 發(fā)表于 12-23 11:34 ?504次閱讀

    Neway電機方案在實際應用中效果如何?

    Neway電機方案在實際應用中效果如何?Neway電機方案是深圳市立維創(chuàng)展科技有限公司推出的電機驅(qū)動與控制系統(tǒng)解決方案,具有高穩(wěn)定性、高性價比、小型化等特點,Neway電機方案在實際應用中效果
    發(fā)表于 12-03 09:23

    房產(chǎn)數(shù)據(jù)平臺安家go獲取地區(qū)列表數(shù)據(jù)的API接口

    如何使用安家go提供的API接口來獲取地區(qū)列表數(shù)據(jù),包括API端點、請求參數(shù)、響應格式以及代碼實現(xiàn)。我們將逐步引導您完成整個過程,確保您能輕松集成到自己的項目中。 1. API概述 安家go的“獲取地區(qū)列表”API是一個基于RE
    的頭像 發(fā)表于 11-21 14:38 ?365次閱讀
    房產(chǎn)數(shù)據(jù)平臺安家<b class='flag-5'>go</b>獲取地區(qū)列表數(shù)據(jù)的API接口

    如何選擇適合自己項目的通信協(xié)議評估工具?

    LZ-DZ200電能質(zhì)量在線監(jiān)測裝置 選擇適合項目的通信協(xié)議評估工具,核心是 對齊項目需求與工具能力 ,避免 “過度選型”(用高端工具測簡單場景)或 “功能不足”(用輕量工具測復雜協(xié)議)。以下是分步
    的頭像 發(fā)表于 08-27 09:19 ?722次閱讀
    如何選擇適合自己<b class='flag-5'>項目的</b>通信協(xié)議評估工具?

    STM32U575VGT6在cubeMX中沒有FATFS中間件,是不支持嗎?

    STM32U575VGT6在cubeMX中沒有FATFS中間件,是不支持?還是待開發(fā)?現(xiàn)在這塊板子使用FATFS只能自己手動移植嗎?
    發(fā)表于 07-30 06:46

    中科創(chuàng)達與ETAS推出預集成多域中間件解決方案

    近日,ETAS 與 ThunderSoft(中科創(chuàng)達)宣布雙方建立了緊密合作關系,并將在今年6月24日至25日于路德維希堡舉行的汽車電子大會上,聯(lián)合展示其新開發(fā)的、面向高性能計算(HPC)SoC 車載系統(tǒng)的多域預集成中間件解決方案。
    的頭像 發(fā)表于 06-25 10:16 ?1273次閱讀

    樹莓派項目中10款最佳的DIN導軌外殼!

    ?模塊化承包商、電源和燈光控制器都集成在一個緊湊的DIN外殼中。一張圖片勝過千言萬語。在本文中,我將討論如何將樹莓派安裝在DIN導軌上。所有提到的產(chǎn)品都已在各種項目中
    的頭像 發(fā)表于 06-14 08:34 ?870次閱讀
    樹莓派<b class='flag-5'>項目中</b>10款最佳的DIN導軌外殼!

    軟件定義汽車時代為什么中間件受青睞

    在“軟件定義汽車”時代,隨著汽車軟件功能漸趨多樣化,硬件和軟件組件之間的通信和交互開始變得復雜。如今,一輛汽車可能負載百余個電子控制單元(ECU),它們分別控制著包括動力轉(zhuǎn)向、溫度控制和安全氣囊等在內(nèi)的多種軟件功能。
    的頭像 發(fā)表于 06-09 11:14 ?1014次閱讀

    鋼廠首選,profinet轉(zhuǎn)profibus在煤電項目中的協(xié)議轉(zhuǎn)換解決方案

    鋼廠首選,profinet轉(zhuǎn)profibus在煤電項目中的協(xié)議轉(zhuǎn)換解決方案
    的頭像 發(fā)表于 05-06 16:37 ?589次閱讀
    鋼廠首選,profinet轉(zhuǎn)profibus在煤電<b class='flag-5'>項目中</b>的協(xié)議轉(zhuǎn)換解決方案

    SDMMC SD_init() 在啟用了TrustZone的項目中永久循環(huán)是怎么回事?

    存儲。 為此,我參考了 SDK sdcard_polling示例。我測試了它,它工作得很好。 然后我決定將代碼、庫和配置復制到我正在處理的項目中(現(xiàn)在,我實際上只是復制了示例的代碼)。 SD 卡 IO 應從安全
    發(fā)表于 03-26 06:02

    智慧路燈的照明效果如何?

    引言 在智慧城市建設的進程中,叁仟智慧路燈已逐漸成為城市道路照明的主力軍。其照明效果不僅關系到市民夜間出行的安全與便捷,更對城市的整體形象和生活品質(zhì)有著深遠影響。相較于傳統(tǒng)路燈,叁仟智慧路燈借助
    的頭像 發(fā)表于 03-16 16:10 ?857次閱讀

    STM32MP131C CbueMX中間件無RTOS選項是怎么回事?

    如題,STM32MP131C CbueMX中間件無RTOS選項,對比選擇STM32MP157芯片是有的,怎么查這部分資料呢
    發(fā)表于 03-14 06:59