我们知道,用户向服务器发起的每一次Web请求,都会通过HTTP协议头部或Body携带许多的请求元信息给服务器,如请求的URL地址,请求方法,请求头部和请求IP地址等等诸多原始信息,而在Gin框架中,我们可以使用日志的方式记录和输出这些信息,记录用户的每一次请求行为。
下面是一条Gin框架在控制台中输出的日志:
[GIN] 2019/05/04 - 22:08:56 | 200 | 5.9997ms | ::1 | GET /test
复制代码
好了,下面看看要如何输出上面的日志吧!
日志中件间
在Gin框架中,要输出用户的http请求日志,最直接简单的方式就是借助日志中间件,下面Gin框架的中间件定义:
func Logger() HandlerFunc
复制代码
所以,当我们使用下面的代码创建一个gin.Engine
时,会在控制台中用户的请求日志:
router := gin.Default()
复制代码
而使用下面的代码创建gin.Engine
时,则不会在控制台输出用户的请求日志:
router := gin.New()
复制代码
这是为什么呢?这是由于使用Default()
函数创建的gin.Engine
实例默认使用了日志中件间gin.Logger()
,所以,当我们使用第二种方式创建gin.Engine
时,可以调用gin.Engine
中的Use()
方法调用gin.Logger()
,如下:
router := gin.New()
router.Use(gin.Logger())
复制代码
在控制台输出日志
Gin框架请求日志默认是在我们运行程序的控制台中输出,而且输出的日志中有些字体有标颜色,如下图所示:
当然,我们可以使用DisableConsoleColor()
函数禁用控制台日志的颜色输出,代码如下所示
gin.DisableConsoleColor()//禁用请求日志控制台字体颜色
router := gin.Default()
router.GET("test",func(c *gin.Context){
c.JSON(200,"test")
})
复制代码
运行后发出Web请求,在控制台输出日志字体则没有颜色:
虽然Gin框架默认是开始日志字体颜色的,但可以使用DisableConsoleColor()
函数来禁用,但当被禁用后,在程序中运行需要重新打开控制台日志的字体颜色输出时,可以使用ForceConsoleColor()
函数重新开启,使用如下:
gin.ForceConsoleColor()