iris 路由注冊和上下文context

路由注冊到app.routes

http請求的處理,相較于基本的net/http包,iris框架將http請求(w,*r)及其它上下文,封裝成ctx,逐個調(diào)用handler閉包進行處理,最后分發(fā)函數(shù)返回值(反射)以及響應(yīng)。請求響應(yīng)相當于流水線上的一個商品,被一組當中的每個handler處理。路由注冊的過程,在完成之前的方法解析,path解析之后,就需要組裝一個handler鏈到路由了。

每一步先由api.relativePath和方法傳入的參數(shù)構(gòu)成fullPath。

第二步然后添加handler,順序為:

  • macroHandler,解析路徑中的參數(shù)值
  • api.middleware,類型為[]handler
  • anymiddleware,由app.Handle()方法傳入
  • 控制器方法的對應(yīng)閉包
  • api.doneHandlers
  • api的全局handlers

第三步構(gòu)建Route:

type Route struct {
        Name       string          `json:"name"`
        Method     string          `json:"method"`
        methodBckp string
        Subdomain  string          `json:"subdomain"`
        tmpl       *macro.Template
        beginHandlers context.Handlers
        Handlers        context.Handlers `json:"-"`
        MainHandlerName string           `json:"mainHandlerName"`
        doneHandlers context.Handlers
        Path         string `json:"path"`
        FormattedPath string `json:"formattedPath"`
}

Name格式為defaultName := method + subdomain + 未注值的路徑格式。其中路徑有三個相關(guān)變量:Subdomain Path FormattedPath。FormattedPath是將path中的:變量替換為%v。構(gòu)建路由Router時將路徑解析的macroHandler,添加在最前面。

最后將路由注冊到app.APIBuilder.routes,類型為[]Route。

context數(shù)據(jù)結(jié)構(gòu)

iris框架定義了handler閉包的操作對象context.context。不是指TCP的context,也不是net/http中的context。數(shù)據(jù)結(jié)構(gòu)如下:

type context struct {
        id uint64
        writer ResponseWriter
        request *http.Request
        currentRouteName string

        app Application
        handlers Handlers
        currentHandlerIndex int
}

前文已經(jīng)提過,由于反射字段的不可復(fù)用性,造成go的反射效率下降。如果處理每次的請求都要在運行時重新構(gòu)建context,就會降低性能。iris用c.pool保存ctx,實現(xiàn)ctx的可復(fù)用。c.pool的類型是sync.pool。id確定ctx的唯一性,方便保存在c.pool集合中。request writer都是net/http標準庫的類型,直接傳遞。

params RequestParams 是一個專用的KV存儲,類型為[string]interface{}。用來保存path param。values用來保存其它KV信息。

app引用自iris實例,可以獲取全部的實例字段。其中路由信息單獨拿出:currentRouteName路由名,對應(yīng)c.routes的鍵。路由handlers,currentHandlerIndex。

ctx是可復(fù)用的,需要構(gòu)建ctx時,不是初始化而是直接從池中拿一個實例。空實例僅配置了app字段。第一步包裝net/http包的(w,*r)。第二步根據(jù)request確定路由信息,并賦到ctx相應(yīng)字段。第三步會執(zhí)行流水線式地Do(handlers),反射調(diào)用得到響應(yīng)信息,并寫入到ctx中。最后一步將針對特定http請求的信息清掉,并放回c.pool。

標準庫中的net/http Request

type Request struct {
    Method string

    URL *url.URL

    Header Header

    Body io.ReadCloser

    GetBody func() (io.ReadCloser, error)

    ContentLength int64

    TransferEncoding []string

    Close bool

    Host string

    Form url.Values

    PostForm url.Values

    MultipartForm *multipart.Form

    Trailer Header

    RemoteAddr string

    RequestURI string

    TLS *tls.ConnectionState

    Cancel <-chan struct{}

    Response *Response

    ctx context.Context
}

標準庫net/http Response

type Response struct {
    Status     string 
    StatusCode int    
    Proto      string 
    ProtoMajor int    
    ProtoMinor int    

    Header Header

    Body io.ReadCloser

    ContentLength int64

    TransferEncoding []string

    Close bool

    Uncompressed bool

    Trailer Header

    Request *Request

    TLS *tls.ConnectionState
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,568評論 19 139
  • 從hello-world開始go iris iris框架是少數(shù)支持MVC的go web框架。在簡單業(yè)務(wù)邏輯測試中,...
    fjxCode閱讀 10,356評論 0 6
  • 主要內(nèi)容:控制器解析、handler注冊。 調(diào)用方法: go語言接口查詢檢測自定義handler是否需要加載 對于...
    fjxCode閱讀 3,937評論 0 0
  • 概述 最近在搞自己的go web開發(fā)框架, 反正也沒打算私藏, 所以現(xiàn)在先拿出url路由設(shè)計這塊來寫一篇博客. 做...
    golanger閱讀 766評論 0 2
  • 黑夜總會醒來 我是喜歡你的, 真的真的喜歡你的 我想我已經(jīng)是屬于你的 在每一個星空浩瀚的夜里 那些星空小小的縮放在...
    許邪清閱讀 243評論 0 9

友情鏈接更多精彩內(nèi)容