使用 GORM 查询数据库时,如何快速过滤结果中的敏感信息?
问题的提出
在使用gorm查询数据库时,我们有时需要过滤查询结果中的某些敏感信息,例如密码等。常规的方法是手动创建映射并循环填充,但有没有更快捷的方法呢?
解决方案
1. gorm 钩子
gorm提供了钩子机制。我们可以使用 afterfind 钩子,在查询完成后自动将敏感信息置空。
func (u *merchant) afterfind(tx *gorm.db) (err error) { u.password = "" return }
2. 部分字段结构体
另一种方法是使用一个仅包含部分子字段的结构体去接收查询结果。
// 仅包含部分子字段的结构体 type MerchantBase struct { Id int `json:"id" gorm:"comment:''"` Username string `json:"username" gorm:"comment:'用户名'"` } // 查询相关 db.Model(&Merchant{}).Find(&MerchantBase{})
以上就是使用 GORM 查询数据库时,如何快速过滤结果中的敏感信息?的详细内容,更多请关注其它相关文章!