在 Go 中生成随机的安全密码

admin 2022年5月23日01:54:38安全开发评论5 views2265字阅读7分33秒阅读模式
 
在 Go 中生成随机的安全密码
导读:Go 的随机数生成器是生成难以猜测的密码的好方法。                                 
本文字数:3098,阅读时长大约:3分钟

LCTT 译者 :六开箱
🌟🌟🌟🌟
在 Go 中生成随机的安全密码
翻译: 60.0 篇

|

贡献: 67 天
2022-03-16
2022-05-21
https://linux.cn/lctt/lkxed

你可以使用 Go 编程语言🔗 golang.org 提供的随机数生成器来生成由 ASCII 字符组成的难以猜测的密码。尽管本文中提供的代码很容易阅读,但是你仍需要了解 Go 的基础知识,才能更好地理解它。如果你是对 Go 还不熟悉,请阅读 Go 语言之旅🔗 tour.golang.org 来了解更多信息,然后返回此处。

在介绍实用程序和它的代码之前,让我们先来看看这个 ASCII 表的子集,它可以在 man ascii 命令的输出中找到:

  1. 30 40 50 60 70 80 90 100 110 120
  2.  ---------------------------------
  3. 0:    (  2  <  F  P  Z  d   n   x
  4. 1:    )  3  =  G  Q  [  e   o   y
  5. 2:    *  4  >  H  R    f   p   z
  6. 3: !  +  5  ?  I  S  ]  g   q   {
  7. 4: "  ,  6  @  J  T  ^  h   r   |
  8. 5: #  -  7  A  K  U  _  i   s   }
  9. 6: $  .  8  B  L  V  `  j   t   ~
  10. 7: %  /  9  C  M  W  a  k   u  DEL
  11. 8: &  0  :  D  N  X  b  l   v
  12. 9: '  1  ;  E  O  Y  c  m   w

在所有 ASCII 字符中,可打印字符的十进制值范围为 33 到 126,其他的 ASCII 值都不适合用于密码。因此,本文介绍的实用程序将生成该范围内的 ASCII 字符。

在 Go 中生成随机的安全密码

生成随机整数

第一个实用程序名为 random.go,它生成指定数量的随机整数,这些整数位于给定范围内。random.go 最重要的部分是这个函数:

  1. func random(min, max int) int {
  2. return rand.Intn(max-min) + min
  3. }

此函数使用了 rand.Intn() 函数来生成一个属于给定范围的随机整数。请注意,rand.Intn() 返回一个属于 [0,n) 的非负随机整数。如果它的参数是一个负数,这个函数将会抛出异常,异常消息是:panic: invalid argument to Intn。你可以在 math/rand 文档🔗 golang.org 中找到 math/rand 包的使用说明。

random.go 实用程序接受三个命令行参数:生成的整数的最小值、最大值和个数。

编译和执行 random.go 会产生这样的输出:

  1. $ go build random.go
  2. $ ./random
  3. Usage: ./random MIX MAX TOTAL
  4. $ ./random 1 3 10
  5. 2 2 1 2 2 1 1 2 2 1

如果你希望在 Go 中生成更安全的随机数,请使用 Go 库中的 crypto/rand 包。

在 Go 中生成随机的安全密码

生成随机密码

第二个实用程序 randomPass.go 用于生成随机密码。randomPass.go 使用 random() 函数来生成随机整数,它们随后被以下 Go 代码转换为 ASCII 字符:

  1. for {
  2. myRand := random(MIN, MAX)
  3. newChar := string(startChar[0] + byte(myRand))
  4. fmt.Print(newChar)
  5. if i == LENGTH {
  6. break
  7. }
  8. i++
  9. }

MIN 的值为 0MAX 的值为 94,而 startChar 的值为 !,它是 ASCII 表中第一个可打印的字符(十进制 ASCII 码为 33)。因此,所有生成的 ASCII 字符都位于 ! 和 ~ 之间,后者的十进制 ASCII 码为 126

因此,生成的每个随机数都大于 MIN,小于 MAX,并转换为 ASCII 字符。该过程继续进行,直到生成的密码达到指定的长度。

randomPass.go 实用程序接受单个(可选)命令行参数,以定义生成密码的长度,默认值为 8,这是一个非常常见的密码长度。执行 randomPass.go 会得到类似下面的输出:

  1. $ go run randomPass.go 1
  2. Z
  3. $ go run randomPass.go 10
  4. #Cw^a#IwkT
  5. $ go run randomPass.go
  6. Using default values!
  7. [[email protected]'Ci

最后一个细节:不要忘记调用 rand.Seed(),并提供一个种子(seed)值,以初始化随机数生成器。如果你始终使用相同的种子值,随机数生成器将生成相同的随机整数序列。

在 Go 中生成随机的安全密码

随机数生成代码

你可以在 GitHub🔗 github.com 找到 random.go 和 randomPass.go 的源码。你也可以直接在 play.golang.org🔗 play.golang.org 上执行它们。

我希望这篇文章对你有所帮助。如有任何问题,请在下方发表评论或在 Twitter🔗 twitter.com 上与我联系。


via: https://opensource.com/article/18/5/creating-random-secure-passwords-go

作者:Mihalis Tsoukalos 选题:lkxed 译者:lkxed 校对:wxy

本文由 LCTT 原创编译,Linux中国 荣誉推出

在 Go 中生成随机的安全密码
欢迎遵照 CC-BY-SA 协议规定转载,
如需转载,请在文章下留言 “转载:公众号名称”,
我们将为您添加白名单,授权“转载文章时可以修改”。


原文始发于微信公众号(Linux中国):在 Go 中生成随机的安全密码 | Linux 中国

特别标注: 本站(CN-SEC.COM)所有文章仅供技术研究,若将其信息做其他用途,由用户承担全部法律及连带责任,本站不承担任何法律及连带责任,请遵守中华人民共和国安全法.
  • 我的微信
  • 微信扫一扫
  • weinxin
  • 我的微信公众号
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2022年5月23日01:54:38
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                  在 Go 中生成随机的安全密码 http://cn-sec.com/archives/1039747.html

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: