gpt4 book ai didi

mysql - 如何在 Go-Gorm 中禁用默认错误记录器

转载 作者:IT王子 更新时间:2023-10-29 01:34:21 39 4
gpt4 key购买 nike

我在 MySQL 中使用 GORM,我遇到并处理了错误 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

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

最佳答案

更新:对于 gorm v2:

使用 Loggergorm.Config 中:

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

对于 gorm v1:

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

LogMode set log mode, true for detailed logs, false for no log, default, will only print error logs.

db.LogMode(false) 应该可以完成这项工作!

关于mysql - 如何在 Go-Gorm 中禁用默认错误记录器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55892035/

39 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com