首页 > 解决方案 > 如何在 Go-Gorm 中禁用默认错误记录器

问题描述

我正在将 GORM 与 MySQL 一起使用,我遇到并处理了错误Error 1062: Duplicate entry。问题是它仍然打印到控制台。

中的代码gym/models/auth.go:49

func AddAuth(username, password string) error {
    passwordHash, err := auth.HashPassword(password, argon2Conf)
    if err != nil {
        return err
    }
    userAuth := Auth{
        Username: username,
        Password: passwordHash,
    }
    return db.Create(&userAuth).Error
}

我正在处理处理函数中的错误:

func SignUpHandler(c *gin.Context) {
    var form user
    if err := c.ShouldBind(&form); err != nil {
        c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
        return
    }
    if err := models.AddAuth(form.Username, form.Password); err == nil {
        c.JSON(http.StatusOK, gin.H{"status": "you are signed in"})
    } else {
        // I think I have handled the sql error here
        c.JSON(http.StatusBadRequest, gin.H{"error": "sign in failed"})
    }
}

当我发送POST请求时,错误得到了正确处理,并且我得到了正确的响应{"error": "sign in failed"}。但控制台仍然会打印此错误消息:

(/...../gym/models/auth.go:49) 
[2019-04-28 23:37:06]  Error 1062: Duplicate entry '123123' for key 'username' 
[GIN] 2019/04/28 - 23:37:06 | 400 |  136.690908ms |             ::1 | POST     /signup

我很困惑,因为我处理了错误,但它仍然被打印出来。如何防止此错误被打印到错误日志中?还是我正确处理错误?

标签: mysqlgoerror-handlinggo-gorm

解决方案


更新:对于 gorm v2

使用Loggerin gorm.Config

db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{
  Logger: logger.Default.LogMode(logger.Silent),
})

对于 gorm v1

使用db.LogMode使默认错误记录器静音。

LogMode 设置日志模式,true为详细日志,false为无日志,默认只打印错误日志。

db.LogMode(false)应该做的工作!


推荐阅读