Maison >développement back-end >Golang >Analyse du code source du processus de demande de gin
Service http de la bibliothèque standard
Handler接口就可以注册到标准库的http server中。然后就会启动一个web应用。http请求流程当发生一个http请求的时候,在内部处理的流程是下面这样的:开启一个协程进行请求处理在conn.serve中调用serverHandler.ServeHTTP 函数如果有自己注册的Handle,那么就会调用注册的Handle的ServeHTTP 方法。这里还要注意的2个点如果自己在启动的时候没有注册自己的Handle,那么会采用标准库默认的ServeMux,全局名称为DefaultServeMux。如果请求URI为*并且请求Method为OPTIONS,那么Handle行为会被改成默认的globalOptionsHandler。上述分析的源码为GO 1.18.3。Gin 处理请求的流程前面我们看到只要注册自己的Handle接口到标准库就可以接管请求的处理;那么我们来看一下gin的Handle接口实现。在gin中,handleHTTPRequest就是匹配路径和对应handle 的处理函数。流程大致是这样:获取请求的路径在trees中找到对应的methodTree
methodTree中匹配对应路径的处理函数handle
Suivant
La méthode exécute la fonction enregistréeNext
方法执行注册的函数在执行注册的函数之前我们发现在ServeHTTP
方法中使用到了一个sync.Pool
,它其实就是对gin.Context
的复用。
我们来看一下它的结构:
// Context is the most important part of gin. It allows us to pass variables between middleware, // manage the flow, validate the JSON of a request and render a JSON response for example. type Context struct { writermem responseWriter Request *http.Request Writer ResponseWriter Params Params handlers HandlersChain index int8 fullPath string engine *Engine params *Params skippedNodes *[]skippedNode // This mutex protects Keys map. mu sync.RWMutex ... }
官方的req
和resp
都会保存在Context
中。并且gin
自己增加了对官方http.ResponseWriter
功能的扩展,也就是自己定义了一个接口gin.ResponseWriter
Avant d'exécuter la fonction enregistrée, nous avons constaté que dans ServeHTTP
utilise une méthode sync.Pool
, qui est en fait gin.Context
réutilisation.
req
et resp
sera enregistré dans Contexte
. etgin
ajout de la prise en charge du http.ResponseWriter
extension de fonction, c'est-à-dire définir soi-même une interfacegin.ResponseWriter
🎜🎜Certaines autres méthodes sont des encapsulations à usage quotidien pour faciliter le développement. 🎜Vous pouvez voir dans le code source qu'un total d'entre elles sont prises en charge Binding
; L'implémentation est la désérialisation, et je n'entrerai pas dans les détails un par un. Binding
;其中的实现就是反序列化,具体的就不在一个一个的说了。
重点是在bind
完成后有一个validate
的方法,它其实是采用的github.com/go-playground/validator/v10
作为验证数据的库。
并采用懒加载的方式进行初始化,也就是说不用,不会初始化这个对象。
其中验证数据的开发流程,请查看validator[1] 的详细用法。
在gin
的mode.go
文件中有控制一些行为的存在,比如DisableBindValidation
bind
Une fois terminé, il y a un style validate
méthode, qui utilise en fait la méthode github.com/go-playground/validator/v10
comme bibliothèque de validation des données. 🎜🎜🎜🎜Et utilisez le chargement paresseux pour l'initialisation, ce qui signifie que vous n'en avez pas besoin, cela l'objet ne sera pas initialisé. 🎜🎜🎜🎜Pour le processus de développement de vérification des données, veuillez vérifier validator🎜[1] . 🎜🎜Dansgin
'smode.go
Le fichier contient des contrôles pour certains comportements, tels que DisableBindValidation
peut désactiver la fonction de validation des données. Cette méthode peut être désactivée en appelant cette méthode avant le démarrage du service. 🎜Ce dossier définit un gin. Objet Moteur
. gin.Engine
对象。
并且也是采用懒加载的方式来进行初始化的。
所以对于想使用全局的gin.Engine
可以采用这个包,这样你就可以不用保存一个自己的全局gin.Engine
gin.Engine
peut utiliser ce package, vous n'avez donc pas besoin de sauvegarder un gin.Engine
objet. 🎜🎜🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!