先解决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
})
... // 后面的代码就不写了
}