1.Golang Gin 实战(十三)| 中间件详解看这一篇就够了
2.成为 Go 高手的博o博 8 个 GitHub 开源项目
3.Golang-gin框架中间件原理
4.Go 语言之在 gin 框架中使用 zap 日志库
5.go-gin框架路由自动注册(iris-mvc方式)附源码
6.使用Golang的HTTP框架gin-gonic开发RESTful API(序)
Golang Gin 实战(十三)| 中间件详解看这一篇就够了
通过这篇文章,我们深入理解了Gin中间件的客源客开精髓。Gin默认提供了两个中间件:Logger 和 Recovery,源系它们帮助我们进行日志记录和panic处理。博o博
一个Gin中间件本质上是客源客开一个HandlerFunc,我们可以通过自定义HandlerFunc来实现自己的源系libev源码分析中间件,如统计请求执行时间。博o博
对于HTTP Basic Authorization,客源客开Gin提供了gin.BasicAuth中间件。源系我们可以通过它为特定URL或分组路由设置认证。博o博例如,客源客开我们添加了一个用户名为admin、源系密码为的博o博账户,用于认证,客源客开只有正确输入用户名和密码才能访问特定资源。源系
责任链模式在Gin中间件中得到了应用,多个对象按照顺序依次处理请求,直至完成或传递给下一个对象。通过这种方式,我们可以在请求处理流程中灵活添加或移除处理逻辑。
通过自定义中间件,我们可以轻松拦截请求,实现日志记录、仿熊猫麻将源码授权校验、过滤等操作,大大增强了Gin框架的灵活性和可扩展性。
为了进一步深入学习Gin框架,这里推荐几篇精彩文章:
使用和源码分析原理实现
HTML模板渲染
XML渲染
JSONP跨域和劫持
JSON渲染输出
成为 Go 高手的 8 个 GitHub 开源项目
想成为 Go 高手吗?推荐以下这些 GitHub 开源项目。
自 年对外公布以来,Go 语言在当前的编程语言中占据了良好的地位,广泛应用于 WEB 领域、云原生领域以及底层服务领域。
Go 语言作为一门相对年轻的语言,既具有 C/C++ 等编译语言的性能和安全性,又具有良好的开发速度。
以下是针对核心库、学习路线、项目和资源进行的分类,以助你进一步扩展对 Go 语言的了解。
核心库
gin
⭐ GitHub stars: k+
Gin 是一个用 Go (Golang) 编写的 HTTP Web 框架,具有类似 Martini 的 API,性能比 Martini 高出 倍。
github.com/gin-gonic/gin
go-zero
⭐ GitHub stars: .2k+
带有 cli 工具的云原生 Go 微服务框架,可提高生产力。
github.com/zeromicro/go-zero
gorm
⭐ GitHub stars: .2k+
Golang 的竞拍源码网站出色 ORM 库,对开发人员非常友好。
github.com/go-gorm/gorm
中间件
etcd
⭐ GitHub stars: .7k+
分布式系统最关键数据的分布式可靠键值存储。
github.com/etcd-io/etcd
Kubernetes
⭐ GitHub stars: .3k+
生产级容器调度和管理。
github.com/kubernetes/kubernetes
学习资源
golang-developer-roadmap
⭐ GitHub stars: .5k+
年成为 Go 开发者的路线图。
github.com/Alikhll/golang-developer-roadmap
项目
go-admin
⭐ GitHub stars: 7.6k+
基于 Gin + Vue + Element UI 的独立前后端权限管理系统的脚手架。
github.com/go-admin-tea/go-admin
资源
awesome-go
⭐ GitHub stars: .1k+
精选的 Go 框架、库和软件的列表。
github.com/avelino/awesome-go
Golang-gin框架中间件原理
什么是中间件
中间件是一个广泛的概念,其含义在不同领域有所不同。在bs/cs软件编程框架中,中间件可以理解为用于解耦业务和非业务代码的钩子函数,这些函数适用于所有或部分请求。
中间件的原理与钩子函数类似。在框架层面,程序运行到某个阶段会自动执行预设的函数,执行完毕后再回到跳出的那个阶段继续执行原函数。
在bs/cs开发中,为了在主体函数前后执行一些通用操作,常见的写法会预设一些钩子,如beforeXxxFunc、afterXxxFunc。但这只有两个函数,传世引擎插件源码且是针对全局请求的。若要实现部分钩子函数针对某些请求,则需要做额外的业务外操作以达到目的。gin框架的中间件就解决了这些痛点。
中间件原理
原理1:每一条请求都处理自己所挂载的所有中间件和唯一主体函数。
普通的钩子函数如图所示:
优点:解耦了业务和非业务代码,非业务代码实现了统一封装使用。
缺点:若想针对某些主体函数不执行或执行其他beforeFunction,需要额外修改框架逻辑。
gin框架中间件如图:
优点:
原理2:洋葱模型。
洋葱模型,如图所示:
beforeFunc1和afterFunc1即是中间件1;afterFunc2和afterFunc2即是中间件2。
请求到来时从最外层开始执行中间件1,然后进入第二层,依次执行完所有中间件最后到达主体函数,接着再一层层往外走再次执行中间件2...中间件1...最后返回,有点像栈的概念。
gin中中间件的实现步骤1
首先,gin把中间件和主体函数统一定义为一个handleFunc。
源码:gin.go
不管是用use()方法注册中间件,还是用restful注册主体函数,类型都是赛车源码公众号HandlerFunc。
源码:routergroup.go
步骤2
把所有handleFunc装入一个数组或叫handleChain的东西。
步骤3
从handleChain的第一个元素开始执行,中间使用c.next、c.Abort等函数进行流程控制。
手动实现一个简单版本的中间件
运行结果:
Go 语言之在 gin 框架中使用 zap 日志库
在 Go 语言中,gin 框架是一个流行的 Web 框架,它默认使用自带的日志库 gin.Default() 的源码 Logger() 和 Recovery() 进行日志记录和错误恢复。
然而,对于需要更强大日志功能的开发者来说,使用 zap 日志库是一个不错的选择。
下面是具体的实操步骤:
1. 运行并访问:localhost:/hello
2. 生成的日志文件为:test.log
3. 如需参考更多内容,请访问:github.com/gin-contrib/...
go-gin框架路由自动注册(iris-mvc方式)附源码
通过分析,gin与iris在路由注册机制上有着明显的差异。gin采用逐条注册方式,而iris-mvc通过将子路由路径与controller方法名关联,实现更为简便的注册。
为了使gin具备iris-mvc的注册便捷性,我们可以采用包装技术,使gin的路由能以子方法名称的方式自动注册。这一方法要求方法名称符合特定格式,如GetTest,代表对test子路径注册get请求的路由。
在自动注册实现过程中,涉及到的文件包括控制器文件(/controller/hello_controller.go)、路由文件(/route/autoRoute.go)和路由管理文件(/route/route.go),最终集成到主程序(/main.go)中。
为了验证自动注册与原生注册方式的性能差异,我们进行了简单性能测试。使用ab工具,分别在阿里云环境下进行1W并发、W请求的测试,比较两种方式的响应时间。
测试结果显示,在性能方面,自动注册方式与原生注册方式表现相当,甚至在特定情况下(如.百分位响应时间),自动注册方式更具优势。因此,在处理1W并发请求场景时,自动注册方式是一个值得考虑的优化方案。
附上源码,供参考与实践。此源码实现了上述功能,帮助开发者轻松地将gin框架的路由注册流程优化为更符合iris-mvc风格的自动化注册流程。
使用Golang的HTTP框架gin-gonic开发RESTful API(序)
使用Golang的HTTP框架gin-gonic开发RESTful API简介
本文将逐步介绍如何利用Golang的gin-gonic框架和MySQL数据库构建一个基础的RESTful API,以博客文章的CRUD操作为例。 首先,确保你已经有一个工作空间,如果没有,可以按照官方指南安装Golang。Glide作为Go的包管理工具,可简化依赖管理,下载并设置其环境。对于Linux用户,通过curl安装,Windows用户则下载官方安装包加入PATH。 接下来,数据定义是核心环节。以博客文章为例,我们需要定义数据模型,同时为CRUD操作设计接口。在项目中,除了gin-gonic,可能还需要安装像bsonId这样的包,以支持文件唯一标识。 在主入口文件main.go中,引入server.go中的控制器函数,启动一个监听端口的简单服务,通过访问localhost:/ping验证API运行状态。 TDD原则也应在此阶段得到应用。在test文件夹下编写测试用例,通过go test进行自动化测试,确保功能的稳定性和数据的正确性。 这个教程还在继续,后续内容将涉及更详细的代码实现和测试策略。通过本文,你将逐步掌握gin-gonic和MySQL在开发RESTful API中的应用。gin框架原理详解(gin框架是什么)
Gin的启动过程、路由及上下文源码解读
Engine是gin框架的一个实例,它包含了多路复用器、中间件和配置中心。
gin通过Engine.Run(addr...string)来启动服务,最终调用的是/手败gin-gonic/gin
一个简单的例子:
packagemain
import"github.com/gin-gonic/gin"
funcmain(){
//Default返回一个默认的路由引擎
r:=gin.Default()
r.GET("/ping",func(c*gin.Context){
//输出json结果给调用方
c.JSON(,gin.H{
"message":"pong",
})
})
r.Run()//listenandserveon0.0.0.0:
}
编译运行程序,打开浏览器,访问页面显示:
{ "message":"pong"}
gin的功能不只是简单输出Json数据。它是一个轻量级的WEB框架,支持RestFull风格API,支持GET,POST,PUT,PATCH,DELETE,OPTIONS等/gin-gonic/gin"
)
funcmain(){
router:=gin.Default()
//静态资源加载,本例为css,js以及资源
router.StaticFS("/public",/ffhelicopter/tmm/website/static"))
router.StaticFile("/favicon.ico","./resources/favicon.ico")
//Listenandserveon0.0.0.0:
router.Run(":")
}
首先需要是生成一个Engine,这是gin的核心,默认带有Logger和Recovery两个中间件。
router:=gin.Default()
StaticFile是加载单个文件,而StaticFS是加载一个完整的目录资源:
func(group*RouterGroup)StaticFile(relativePath,filepathstring)IRoutes
func(group*RouterGroup)StaticFS(relativePathstring,fs/gin-gonic/gin
如果安装失败,直接去Githubclone下来,放置到对应的目录即可。
(2)代码中使用:
下面是一个使用Gin的简单例子:
packagemain
import(
"github.com/gin-gonic/gin"
)
funcmain(){
router:=gin.Default()
router.GET("/ping",func(c*gin.Context){
c.JSON(,gin.H{
"message":"pong",
})
})
router.Run(":")//listenandserveon0.0.0.0:
}
简单几行代码,就能实现一个web服务。使用gin的Default方法创建一个路由handler。然后通过HTTP方法绑定路由规则和路由函数。不同于net/e"}。
注:Gin还包含更多的返回方法如c.String,c.HTML,c.XML等,请自行了解。可以方便的返回HTML数据
我们在之前的组v1路由下新定义一个路由:
下面我们访问
可以看到,通过c.Param(“key”)方法,Gin成功捕获了url请求路径中的参数。同理,gin也可以捕获常规参数,如下代码所示:
在浏览器输入以下代码:
通过c.Query(“key”)可以成功接收到url参数,c.DefaultQuery在参数不存在的情况下,会由其默认值代替。
我们还可以为Gin定义一些默认路由:
这时候,我们访问一个不存在的页面:
返回如下所示:
下面我们测试在Gin里面使用Post
在测试端输入:
附带发送的数据,测试即可。记住需要使用POST方法.
继续修改,将PostHandler的函数修改如下
测试工具输入:
发送的内容输入:
返回结果如下:
备注:此处需要指定Content-Type为application/x-www-form-urlencoded,否则识别不出来。
一定要选择对应的PUT或者DELETE方法。
Gin框架快速的创建路由
能够方便的创建分组
支持url正则表达式
支持参数查找(c.Paramc.Queryc.PostForm)
请求方法精准匹配
支持处理
快速的返回给客户端数据,常用的c.Stringc.JSONc.Data