golang 解決windows控制檯 Gin&&GORM.v2 日誌輸出亂碼,無顏色問題

先解決gin框架日誌輸入無顏色,並且有亂碼的問題

windows下使用gin框架,默認日誌輸出的時候,總是會有亂碼,細細查看後是顏色代碼,網上找出路後發現可以這樣解決

import (
	"github.com/gin-gonic/gin"
	"github.com/mattn/go-colorable" // 改包可完美解決問題
)

func main() {
	// 啓用gin的日誌輸出帶顏色
	gin.ForceConsoleColor()
	// 替換默認Writer(關鍵步驟)
	gin.DefaultWriter = colorable.NewColorableStdout()

	r := gin.Default()
	r.GET("/ping", func(c *gin.Context) {
		c.String(200, "Hello World")
	})

	router.Run(":8080")
}

對GORM的日誌輸出,同樣參照以上方案解決即可

import (
	"github.com/mattn/go-colorable" // 改包可完美解決問題
	... // 其他的包這裏就不寫了
)

func main() {
	// newLogger 新建Logger
	var newLogger = logger.New(
		// io.writer同樣使用colorable
		log.New(colorable.NewColorableStdout(), "\r\n", log.LstdFlags),
		logger.Config{
			SlowThreshold: time.Second, // 慢 SQL 閾值
			LogLevel:      logger.Info, // Log level
			Colorful:      true,       // 開啓彩色打印
		},
	)
	
	dsn := loginName + ":" + loginPwd + 	"@(" + host + ":" + port + ")/" + dbName + "?charset=utf8mb4&parseTime=True&loc=Local"
	db, err = gorm.Open(mysql.Open(dsn), &gorm.Config{
		Logger: newLogger, // 使用上面新建的newLogger 
	})
	
	... // 後面的代碼就不寫了
}

參考

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章