iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > GO >Go x/crypto/bcrypt:生成密码哈希时使用自定义盐
  • 790
分享到

Go x/crypto/bcrypt:生成密码哈希时使用自定义盐

2024-04-05 00:04:04 790人浏览 泡泡鱼
摘要

有志者,事竟成!如果你在学习golang,那么本文《Go x/crypto/bcrypt:生成密码哈希时使用自定义盐》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个

有志者,事竟成!如果你在学习golang,那么本文《Go x/crypto/bcrypt:生成密码哈希时使用自定义盐》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

我正在尝试为 Go 服务器实现一个基本身份验证系统,该系统由具有多个服务器生成的密码(本质上是令牌)的用户组成,这些密码必须安全地存储在数据库中。

实现这一目标的一种方法是使用单向函数和全局唯一的盐对密码进行哈希处理。

但是,由于在我的例子中用户有多个密码,这会造成身份验证问题;每个用户的密码可能有不同的盐,因此服务器需要迭代数据库中的密码,使用与数据库中相同的盐对提供的密码进行哈希处理,然后进行比较。这似乎效率不高。

或者,我认为我可以放宽对盐的“全局唯一”约束,并在创建用户时随机生成盐,并将其用于该用户的所有密码。这样,我只需对用户提供的密码进行一次哈希处理,然后就可以使用 sql 查询来执行身份验证。这也是相关问题中建议的解决方案。

但是,Go x/crypto/bcrypt 包不会公开使用自定义盐对密码进行哈希处理的函数,其盐生成是私有的。这是有充分理由的吗?这种对所有用户密码使用普通盐的方法是否存在漏洞?

考虑到像 GitHubgitLab 这样的网站必须处理其个人访问令牌存储,这个问题似乎很常见,但 GitLab(默认情况下)似乎只是对其生成的令牌执行 sha256 哈希。


正确答案


根据设计,每个哈希都有自己的盐,它存储在数据库中。作为带有盐、密码散列、bcrypt 通行证等的字符串。似乎所有或大多数较新的一代加密技术都这样做,因此每个散列都必须单独破解。如果您希望在代码中存储某些内容,我会在每个密码中添加一个胡椒,然后让它们的盐在数据库中是唯一的。

您担心迭代每个密码的效率,但我不会,安全性可能比您的登录效率更好。只需将他们的登录会话存储 x 天?

是否存在漏洞

嗯,是的,如果这是一个答案,bcrypt 本身就被认为是脆弱的?

我认为你应该选择 argon2id,因为它今天被认为是“好的”,而且你的程序是新的 https://pkg.go.dev/golang.org/x/crypto/argon2 这是一个包装器,因此就 Go 加密而言,它是安全的,并且非常易于使用: Https://github.com/alexedwards/argon2id

如果您想要令牌,您可能应该使用 UUID

本篇关于《Go x/crypto/bcrypt:生成密码哈希时使用自定义盐》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注编程网公众号!

您可能感兴趣的文档:

--结束END--

本文标题: Go x/crypto/bcrypt:生成密码哈希时使用自定义盐

本文链接: https://www.lsjlt.com/news/596825.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Go x/crypto/bcrypt:生成密码哈希时使用自定义盐
    有志者,事竟成!如果你在学习Golang,那么本文《Go x/crypto/bcrypt:生成密码哈希时使用自定义盐》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个...
    99+
    2024-04-05
  • 无法使用自定义 crypto.Signer 实现生成 X.509 证书
    php小编柚子在这里为大家介绍一个关于生成 X.509 证书的问题。有时候在使用自定义 crypto.Signer 实现生成证书的过程中,可能会遇到一个无法使用的问题。这个问题可能会让...
    99+
    2024-02-10
    加密货币
  • 如何使用代码生成器自定义Entity
    今天小编给大家分享一下如何使用代码生成器自定义Entity的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。代码生成器自定义En...
    99+
    2023-06-30
  • 使用 Go 通过自定义 io.Reader 确定性生成 RSA 私钥
    php小编百草将为大家介绍如何使用Go语言通过自定义io.Reader接口来确定性生成RSA私钥。RSA是一种非对称加密算法,常用于数据加密和数字签名。在生成RSA私钥时,通常需要从随...
    99+
    2024-02-09
    go语言
  • 使用代码生成器自定义Entity的部分注解
    目录代码生成器自定义Entity部分注解前因查找了我的代码生成器那个配置类随后在templates/entity.java.ftl里还有一点代码生成器最新版配置方案代码生成器自定义E...
    99+
    2024-04-02
  • 如何在Java中使用路径来生成自定义二维码对象?
    Java是一种广泛使用的编程语言,因其跨平台性和易于学习的特点而受到了广泛的认可。在这篇文章中,我们将介绍如何在Java中使用路径来生成自定义二维码对象。 二维码是一种可以快速扫描的矩形图形,其中包含了一些信息,例如URL、文本和其他数据。...
    99+
    2023-08-29
    二维码 对象 path
  • 如何在Linux系统中使用Python和Apache生成二维码并进行自定义?
    Linux系统是一种强大的操作系统,它可以帮助我们完成各种任务。Python是一种非常流行的编程语言,它可以用来创建各种类型的应用程序。Apache是一种流行的Web服务器,它可以帮助我们在Web上发布应用程序和网站。在本文中,我们将介绍如...
    99+
    2023-07-23
    linux apache 二维码
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作