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 
	})
	
	... // 后面的代码就不写了
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值