小白教程
所有教程
关于
Search
172.71.254.251
172.71.254.251
参数设置
贡献
退出
操作
编辑
移动
保护
信息
历史
删除
查看“Golang Gin 日志”的源代码
本页内容
上一节:
Golang_Gin_中间件使用
下一节:
Golang_Gin_部署上线
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
[[分类:Golang Gin Web 框架教程]] 开发的应用程序记录日志是一个非常好的习惯,便于我们观察应用程序运行的情况,方便排查分析问题,Gin提供了简单高效的记录日志方法。 == 如何记录日志 == <sample title="" desc=""> func main() { // 禁用控制台颜色,将日志写入文件时不需要控制台颜色。 gin.DisableConsoleColor() // 记录到文件。 f, _ := os.Create("gin.log") gin.DefaultWriter = io.MultiWriter(f) // 如果需要同时将日志写入文件和控制台,请使用以下代码。 // gin.DefaultWriter = io.MultiWriter(f, os.Stdout) router := gin.Default() router.GET("/ping", func(c *gin.Context) { c.String(200, "pong") }) router.Run(":8080") } </sample> == 定义路由日志的格式 == 默认的路由日志格式: <pre> [GIN-debug] POST /foo --> main.main.func1 (3 handlers) [GIN-debug] GET /bar --> main.main.func2 (3 handlers) [GIN-debug] GET /status --> main.main.func3 (3 handlers) </pre> 如果你想要以指定的格式(例如 JSON,key values 或其他格式)记录信息,则可以使用 gin.DebugPrintRouteFunc 指定格式。 在下面的示例中,我们使用标准日志包记录所有路由,但你可以使用其他满足你需求的日志工具。 <sample title="" desc=""> import ( "log" "net/http" "github.com/gin-gonic/gin" ) func main() { r := gin.Default() gin.DebugPrintRouteFunc = func(httpMethod, absolutePath, handlerName string, nuHandlers int) { log.Printf("endpoint %v %v %v %v\n", httpMethod, absolutePath, handlerName, nuHandlers) } r.POST("/foo", func(c *gin.Context) { c.JSON(http.StatusOK, "foo") }) r.GET("/bar", func(c *gin.Context) { c.JSON(http.StatusOK, "bar") }) r.GET("/status", func(c *gin.Context) { c.JSON(http.StatusOK, "ok") }) // 监听并在 0.0.0.0:8080 上启动服务 r.Run() } </sample> == 控制日志输出颜色 == 根据检测到的 TTY,控制台的日志输出默认是有颜色的。 禁止日志高亮显示: <sample title="" desc=""> func main() { // 禁止日志的颜色 gin.DisableConsoleColor() // 用默认中间件创建一个 gin 路由: // 日志和恢复(无崩溃)中间件 router := gin.Default() router.GET("/ping", func(c *gin.Context) { c.String(200, "pong") }) router.Run(":8080") } </sample> === 日志高亮显示: === <sample title="" desc=""> func main() { // 强制日志颜色化 gin.ForceConsoleColor() // 用默认中间件创建一个 gin 路由: // 日志和恢复(无崩溃)中间件 router := gin.Default() router.GET("/ping", func(c *gin.Context) { c.String(200, "pong") }) router.Run(":8080") } </sample>
返回至“
Golang Gin 日志
”。
上一节:
Golang_Gin_中间件使用
下一节:
Golang_Gin_部署上线