登录
首页 >  Golang >  Go问答

我可以使用 Go 中的"crypto/rand"包生成唯一的随机字符串吗?

来源:stackoverflow

时间:2024-02-20 23:42:24 429浏览 收藏

有志者,事竟成!如果你在学习Golang,那么本文《我可以使用 Go 中的"crypto/rand"包生成唯一的随机字符串吗?》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

我想生成 32 个字符长的 unique unguessable 字母数字密钥。密钥将成为我的系统的标识符,并将用于查找信息。

在网上搜索时,我偶然发现了 Gocrypto/rand 包。它能够在下划线系统调用的帮助下生成随机字母数字。但我担心 crypto/rand 包返回的值可能会产生一个非唯一的字符串。

任何人都可以澄清我是否可以依赖 crypto/rand 包来完成这项工作吗?


正确答案


当然,对于随机生成的令牌,总是有可能生成重复的令牌。有一些标准,例如 UUID(不包括 v4),使用其他方法来尝试“保证”每个标识符的唯一性。这些方法并不能真正消除碰撞的可能性,它们只是改变了故障模式。例如,UUID1 依赖于 uniqueness of MAC addresses,这本身就是一个完整的问题。

如果你不受令牌大小的限制,你可以轻松地选择足够多的位,使碰撞的概率变得如此之小,以至于与无数其他故障模式(例如程序员错误、宇宙射线、大规模全球灭绝事件等)。

非常近似的是,如果您有 N 位的真正随机密钥长度,则可以在有 50% 的机会看到冲突之前生成 2^(N/2) 个密钥。有关更通用的公式,请参阅 Wikipedia 页面 UUID#Collisions

今天关于《我可以使用 Go 中的"crypto/rand"包生成唯一的随机字符串吗?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>