Go Web轻量级框架Gin学习系列:HTTP请求日志

我们知道,用户向服务器发起的每一次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()
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值