Go語言HTTPServer開發(fā)的六種方式小結(jié)
學完了net/http和fasthttp兩個HTTP協(xié)議接口的客戶端實現(xiàn),接下來就要開始Server的開發(fā),不學不知道一學嚇一跳,居然這兩個庫還支持Server的開發(fā),太方便了。相比于Java的HTTPServer開發(fā)基本上都是使用Spring或者Springboot框架,總是要配置各種配置類,各種handle對象。Golang的Server開發(fā)顯得非常簡單,就是因為特別簡單,或者說沒有形成特別統(tǒng)一的規(guī)范或者框架,我發(fā)現(xiàn)了很多實現(xiàn)方式,HTTP協(xié)議基于還是net/http和fasthttp,但是handle語法就多種多樣了。
先復習一下:Golang語言HTTP客戶端實踐、Golang fasthttp實踐。 在Golang語言方面,實現(xiàn)某個功能的庫可能會比較多,有機會還是要多跟同行交流,指不定就發(fā)現(xiàn)了更好用的庫。下面我分享我學到的六種Server開發(fā)的實現(xiàn)Demo。
第一種
基于net/http實現(xiàn),這是一種比較基礎的,對于接口和handle映射關系處理并不優(yōu)雅,不推薦使用。
func TestHttpSer(t *testing.T) { server := http.Server{ Addr: ":8001", Handler: http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { if strings.Index(r.URL.String(), "test") > 0 { fmt.Fprintf(w, "這是net/http創(chuàng)建的server第一種方式") return } fmt.Fprintf(w, task.FunTester) return }), } server.ListenAndServe() log.Println("開始創(chuàng)建HTTP服務") }
第二種
第二種也是基于net/http,這種編寫語法可以很好地解決第一種的問題,handle和path有了類似配置的語法,可讀性提高了很多。
type indexHandler struct { content string } func (ih *indexHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, ih.content) } func TestHttpSer2(t *testing.T) { http.Handle("/test", &indexHandler{content: "這是net/http第二種創(chuàng)建服務語法"}) http.Handle("/", &indexHandler{content: task.FunTester}) http.ListenAndServe(":8001", nil) }
第三種
第三個基于net/http和github.com/labstack/echo,后者主要提供了Echo對象用來處理各類配置包括接口和handle映射,功能很豐富,可讀性最佳。
func TestHttpSer3(t *testing.T) { app := echo.New() app.Use(middleware.CORSWithConfig(middleware.CORSConfig{ AllowOrigins: []string{"*"}, AllowMethods: []string{echo.GET, echo.DELETE, echo.POST, echo.OPTIONS, echo.PUT, echo.HEAD}, AllowHeaders: []string{echo.HeaderContentType, echo.HeaderAuthorization}, })) app.Group("/test") { projectGroup := app.Group("/test") projectGroup.GET("/", PropertyAddHandler) } app.Server.Addr = ":8001" gracehttp.Serve(app.Server) }
第四種
第四種依然基于net/http實現(xiàn),引入了github.com/gin-gonic/gin的路由,看起來接口和handle映射關系比較明晰了。
func TestHttpServer4(t *testing.T) { router := gin.New() api := router.Group("/okreplay/api") { api.POST("/submit", gin.HandlerFunc(func(context *gin.Context) { context.ShouldBindJSON(map[string]interface{}{ "code": 0, "msg": "這是創(chuàng)建HTTPServer第四種方式", }) context.Status(200) })) } s := &http.Server{ Addr: ":8001", Handler: router, ReadTimeout: 1000 * time.Second, WriteTimeout: 1000 * time.Second, MaxHeaderBytes: 1 << 20, } s.ListenAndServe() }
第五種
第五種基于fasthttp開發(fā),使用都是fasthttp提供的API,可讀性尚可,handle配置倒是更像Java了。
func TestFastSer(t *testing.T) { address := ":8001" handler := func(ctx *fasthttp.RequestCtx) { path := string(ctx.Path()) switch path { case "/test": ctx.SetBody([]byte("這是fasthttp創(chuàng)建服務的第一種語法")) default: ctx.SetBody([]byte(task.FunTester)) } } s := &fasthttp.Server{ Handler: handler, Name: "FunTester server", } if err := s.ListenAndServe(address); err != nil { log.Fatal("error in ListenAndServe", err.Error()) } }
第六種
第六種依然基于fasthttp,用到了github.com/buaazp/fasthttprouter,有點奇怪兩個居然不在一個GitHub倉庫里。使用語法跟第三種方式有點類似,比較有條理,有利于閱讀。
func TestFastSer2(t *testing.T) { address := ":8001" router := fasthttprouter.New() router.GET("/test", func(ctx *fasthttp.RequestCtx) { ctx.Response.SetBody([]byte("這是fasthttp創(chuàng)建server的第二種語法")) }) router.GET("/", func(ctx *fasthttp.RequestCtx) { ctx.Response.SetBody([]byte(task.FunTester)) }) fasthttp.ListenAndServe(address, router.Handler) }
到此這篇關于Go語言HTTPServer開發(fā)的六種實現(xiàn)小結(jié)的文章就介紹到這了,更多相關Go HTTPServer 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Go語言實現(xiàn)關閉http請求的方式總結(jié)
面試的時候問到如何關閉http請求,一般人脫口而出的是關閉response.body,這是錯誤的。本文為大家整理了三個正確關閉http請求的方法,希望對大家有所幫助2023-02-02一文帶你搞懂Golang結(jié)構(gòu)體內(nèi)存布局
結(jié)構(gòu)體在Go語言中是一個很重要的部分,在項目中會經(jīng)常用到。這篇文章主要帶大家看一下結(jié)構(gòu)體在內(nèi)存中是怎么分布的?通過對內(nèi)存布局的了解,可以幫助我們寫出更優(yōu)質(zhì)的代碼。感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助2022-10-10